Systems and Methods for Digital Radio Broadcast with Cross Platform Reception
Systems and methods are described for rendering content at a digital radio broadcast receiver system. A digital radio broadcast signal comprises data for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error. A portion of the data containing the data error is identified. A download request is transmitted to a computing system, where the download request requests duplicate data for the portion of the data containing the data error. The duplicate data is received at the digital radio broadcast receiver for the portion of the data containing the error via other wireless communication other than the digital radio broadcast. The duplicate data is processed to provide an uninterrupted rendering of the content.
This application is a continuation of U.S. patent application Ser. No. 14/580,920 entitled Systems and Methods for Digital Radio Broadcast with Cross Platform Reception filed Dec. 23, 2014, the entire contents of which are incorporated herein by reference.
FIELDThe technology described in this patent document relates generally to digital radio broadcasting and more particularly to systems and methods for providing an uninterrupted rendering of content at a digital radio broadcast receiver.
BACKGROUNDDigital radio broadcasting technology delivers digital audio and data services to mobile, portable, and fixed receivers. One type of digital radio broadcasting, referred to as in-band on-channel (IBOC) digital audio broadcasting (DAB), uses terrestrial transmitters in the existing Medium Frequency (MF) and Very High Frequency (VHF) radio bands. HD Radio™ technology, developed by iBiquity Digital Corporation, is one example of an IBOC implementation for digital radio broadcasting and reception. One feature of digital transmission systems is the inherent ability to simultaneously transmit both digitized audio and data. Thus the technology also allows for wireless data services from AM and FM radio stations. The broadcast signals can include metadata, such as the artist name, song title, or station call letters. Special messages about events, traffic, and weather can also be included. For example, traffic information, weather forecasts, news, and sports scores can all be scrolled across a radio receiver's display while the user listens to a radio station.
IBOC digital radio broadcasting technology can provide digital quality audio, superior to existing analog broadcasting formats. Because each IBOC digital radio broadcasting signal is transmitted within the spectral mask of an existing AM or FM channel allocation, it requires no new spectral allocations. IBOC digital radio broadcasting promotes economy of spectrum while enabling broadcasters to supply digital quality audio to the present base of listeners.
Multicasting, the ability to deliver several audio programs or services over one channel in the AM or FM spectrum, enables stations to broadcast multiple services and supplemental programs on any of the sub-channels of the main frequency. For example, multiple data services can include alternative music formats, local traffic, weather, news, and sports. The supplemental services and programs can be accessed in the same manner as the traditional station frequency using tuning or seeking functions. For example, if the analog modulated signal is centered at 94.1 MHz, the same broadcast in IBOC can include supplemental services 94.1-2, and 94.1-3. Highly specialized supplemental programming can be delivered to tightly targeted audiences, creating more opportunities for advertisers to integrate their brand with program content. As used herein, multicasting includes the transmission of one or more programs in a single digital radio broadcasting channel or on a single digital radio broadcasting signal. Multicast content can include a main program service (MPS), supplemental program services (SPS), program service data (PSD), and/or other broadcast data.
The National Radio Systems Committee, a standard-setting organization sponsored by the National Association of Broadcasters and the Consumer Electronics Association, adopted an IBOC standard, designated NRSC-5, in September 2005. NRSC-5 and its updates, the disclosure of which are incorporated herein by reference, set forth the requirements for broadcasting digital audio and ancillary data over AM and FM broadcast channels. The standard and its reference documents contain detailed explanations of the RF/transmission subsystem and the transport and service multiplex subsystems. Copies of the standard can be obtained from the NRSC at http://www.nrscstandards.org/SG.asp. iBiquity's HD Radio technology is an implementation of the NRSC-5 IBOC standard. Further information regarding HD Radio technology can be found at www.hdradio.com and www.ibiquity.com.
Other types of digital radio broadcasting systems include satellite systems such as Satellite Digital Audio Radio Service (SDARS, e.g., XM Radio, Sirius), Digital Audio Radio Service (DARS, e.g., WorldSpace), and terrestrial systems such as Digital Radio Mondiale (DRM), Eureka 147 (branded as DAB Digital Audio Broadcasting), DAB Version 2, and FMeXtra. As used herein, the phrase “digital radio broadcasting” encompasses digital audio broadcasting including in-band on-channel broadcasting, as well as other digital terrestrial broadcasting and satellite broadcasting.
Digital radio broadcast signals are subject to intermittent fades or blockages that result in problems with signal quality for signals received at a digital radio broadcast receiver system. Further, there are some blockages that sufficiently obscure the broadcast signal from the receiver for periods of time, and thereby produce a gap in the reception of the broadcast signal.
SUMMARYThe present inventors have observed a need for systems and methods for mitigating the effect of the signal quality problems described above. Embodiments of the present disclosure are directed to systems and methods that may satisfy this need. The present disclosure is directed to a computer-implemented method, system, and non-transitory computer-readable storage medium for rendering content at a digital radio broadcast receiver system. In an example computer-implemented method for rendering content at a digital radio broadcast receiver system, a digital radio broadcast signal is received via digital radio broadcast transmission, the digital radio broadcast signal comprising data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error, and a portion of the data containing the data error is identified. A notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data for the portion of the data containing the data error. The duplicate data is received at the digital radio broadcast receiver for the portion of the data containing the error via other wireless communication other than the digital radio broadcast transmission based on the notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data is selected instead of selecting the portion of the data that contains the data error to provide corrected data, and the corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
A digital radio broadcast receiver system configured to render content includes a processing system and a memory coupled to the processing system. The processing system is configured to execute steps. In executing the steps, a digital radio broadcast signal is received via digital radio broadcast transmission, the digital radio broadcast signal comprising data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error, and a portion of the data containing the data error is identified. A notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data for the portion of the data containing the data error. The duplicate data is received at the digital radio broadcast receiver for the portion of the data containing the error via other wireless communication other than the digital radio broadcast transmission based on the notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data is selected instead of selecting the portion of the data that contains the data error to provide corrected data, and the corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
In an example non-transitory computer-readable storage medium for rendering content at a digital radio broadcast receiver system, the computer-readable storage medium includes computer-executable instructions which, when executed, cause a processing system to execute steps. In executing the steps, a digital radio broadcast signal is received via digital radio broadcast transmission, the digital radio broadcast signal comprising data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error, and a portion of the data containing the data error is identified. A notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data for the portion of the data containing the data error. The duplicate data is received at the digital radio broadcast receiver for the portion of the data containing the error via other wireless communication other than the digital radio broadcast transmission based on the notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data is selected instead of selecting the portion of the data that contains the data error to provide corrected data, and the corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
In an embodiment of the computer-implemented method, system, and non-transitory computer-readable storage medium described herein, the content to be rendered at the digital radio broadcast receiver system comprises an audio program. In this embodiment, the data from the digital radio broadcast transmission is audio data, and the digital radio broadcast signal may include program data identifying the audio program. Further, in this embodiment, the duplicate data may be received without receiving data via the other wireless communication for the entire audio program. In another embodiment of the computer-implemented method, system, and non-transitory computer-readable storage medium described herein, the content to be rendered at the digital radio broadcast receiver system comprises one or more data services (e.g., local traffic information, weather forecasts, news, sports scores, finance information, etc., that may be rendered at a display device of the receiver system, for example).
In an example computer-implemented method for rendering content at a digital radio broadcast receiver system, a digital radio broadcast signal is received via digital radio broadcast transmission. The digital radio broadcast signal comprises data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error. A first notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data to be transmitted via other wireless communication other than the digital radio broadcast transmission for rendering the content. The duplicate data permits the content to be rendered without the data error. The duplicate data is received at the digital radio broadcast receiver without the error via the other wireless communication based on the first notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data received via the other wireless communication without the error for rendering at the receiver is selected instead of selecting the data received by digital radio broadcast transmission that contains the data error so as to provide corrected data. The corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
In an example non-transitory computer-readable storage medium for rendering content at a digital radio broadcast receiver system, the computer-readable storage medium includes computer-executable instructions which, when executed, cause a processing system to execute steps. In executing the steps, a digital radio broadcast signal is received via digital radio broadcast transmission. The digital radio broadcast signal comprises data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error. A first notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data to be transmitted via other wireless communication other than the digital radio broadcast transmission for rendering the content. The duplicate data permits the content to be rendered without the data error. The duplicate data is received at the digital radio broadcast receiver without the error via the other wireless communication based on the first notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data received via the other wireless communication without the error for rendering at the receiver is selected instead of selecting the data received by digital radio broadcast transmission that contains the data error so as to provide corrected data. The corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
In an example non-transitory computer-readable storage medium for rendering content at a digital radio broadcast receiver system, the computer-readable storage medium includes computer-executable instructions which, when executed, cause a processing system to execute steps. In executing the steps, a digital radio broadcast signal is received via digital radio broadcast transmission. The digital radio broadcast signal comprises data in a specified format for rendering content at the digital radio broadcast receiver. The digital radio broadcast signal is processed to determine whether the data from the digital radio broadcast transmission contains a data error. A first notification is transmitted to a computing system, where the notification is effective to cause the processing of duplicate data to be transmitted via other wireless communication other than the digital radio broadcast transmission for rendering the content. The duplicate data permits the content to be rendered without the data error. The duplicate data is received at the digital radio broadcast receiver without the error via the other wireless communication based on the first notification. The duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system. The duplicate data received via the other wireless communication without the error for rendering at the receiver is selected instead of selecting the data received by digital radio broadcast transmission that contains the data error so as to provide corrected data. The corrected data is processed at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
In an example computer-implemented method for communicating data from a digital radio broadcast transmission system to a digital radio broadcast receiver system, encoded data is received at a digital radio broadcast transmitter system. A data structure based on the encoded data is generated, where contents of the data structure include data configured to be rendered by a digital radio broadcast receiver. The data structure is encapsulated in a file, the file having a format that allows the file to be transferred via an Internet protocol. The file is transmitted to a computing system using the Internet protocol, and the computing system stores the file in a non-transitory computer-readable storage medium. A digital radio broadcast signal including the data structure is broadcasted via digital radio broadcast transmission for reception at the digital radio broadcast receiver. A first notification is received from the digital radio broadcast receiver, the first notification being indicative that the encoded data from the digital radio broadcast transmission contains a data error. The file is sent to the digital radio broadcast receiver via wireless transmission other than digital radio broadcast transmission to provide duplicate data in place of the encoded data of the digital radio broadcast transmission that contains the data error.
An example digital radio broadcast transmission system includes a computing system and a digital radio broadcast transmitter system including a processing system. The digital radio broadcast transmission system further includes a memory coupled to the processing system, where the processing system is configured to execute steps. In executing the steps, encoded data is received at a digital radio broadcast transmitter system. A data structure is generated based on the encoded data, where contents of the data structure include data configured to be rendered by a digital radio broadcast receiver. The data structure is encapsulated in a file, the file having a format that allows the file to be transferred via an Internet protocol. The file is transmitted to the computing system using the Internet protocol, and the computing system stores the file in a non-transitory computer-readable storage medium. A digital radio broadcast signal including the data structure is broadcasted via digital radio broadcast transmission for receipt at the digital radio broadcast receiver. The computing system is configured to receive a first notification from the digital radio broadcast receiver, the first notification being indicative that the encoded data from the digital radio broadcast transmission contains a data error. The computing system is configured to process the file for transmission to the digital radio broadcast receiver via other wireless communication other than the digital radio broadcast transmission to provide duplicate data in place of the encoded data of the digital radio broadcast transmission that contains the data error.
An example article of manufacture includes a non-transitory computer readable storage medium having computer program instructions for communicating data from a digital radio broadcast transmission system to a digital radio broadcast receiver system. The instructions include first instructions which when executed are adapted to cause a processing system of a digital radio broadcast transmitter system to execute steps. In executing the steps, encoded data is received at a digital radio broadcast transmitter system. A data structure is generated based on the encoded data, where contents of the data structure include data configured to be rendered by a digital radio broadcast receiver. The data structure is encapsulated in a file, the file having a format that allows the file to be transferred via an Internet protocol. The file is transmitted to a computing system using the Internet protocol, and the computing system stores the file in a non-transitory computer-readable storage medium. A digital radio broadcast signal including the data structure is broadcasted via digital radio broadcast transmission for receipt at the digital radio broadcast receiver. The instructions further include second instructions which when executed are adapted to cause the computing system to execute second steps. In executing the second steps, a first notification is received from the digital radio broadcast receiver, the first notification being indicative that the encoded data from the digital radio broadcast transmission contains a data error. Further, in executing the second steps, the file is processed for transmission to the digital radio broadcast receiver via other wireless communication other than the digital radio broadcast transmission to provide duplicate data in place of the encoded data of the digital radio broadcast transmission that contains the data error.
These and other features, aspects, and advantages of the present disclosure will become better understood with regard to the following description, appended claims, and accompanying drawings wherein:
Digital radio broadcast signals received at a digital radio broadcast receiver may include data containing one or more errors. The present inventors have developed novel systems and methods to mitigate the effect of these errors. Certain aspects of the systems and methods are implemented at a transmitter side, while other aspects are implemented at a receiver side. The approaches described herein may be used in providing an uninterrupted rendering of content (e.g., any one of audio, video, text, still images, multimedia, etc., or a combination thereof) at the digital radio broadcast receiver.
Exemplary Digital Radio Broadcasting System
As referred to herein, a service is any analog or digital medium for communicating content via radio frequency broadcast. For example, in an IBOC radio signal, the analog modulated signal, the digital main program service, and the digital supplemental program services could all be considered services. Other examples of services can include conditionally accessed programs (CAs), which are programs that require a specific access code and can be both audio and/or data such as, for example, a broadcast of a game, concert, or traffic update service, and data services, such as traffic data, multimedia and other files, and service information guides (SIGs).
Additionally, as referred to herein, media content is any substantive information or creative material, including, for example, audio, video, text, image, or metadata, that is suitable for processing by a processing system to be rendered, displayed, played back, and/or used by a human.
Referring to the drawings,
At the studio site, the studio automation equipment supplies main program service (MPS) audio 42 to the EASU, MPS data 40 to the exporter, supplemental program service (SPS) audio 38 to the importer, and SPS data 36 to the importer 18. MPS audio serves as the main audio programming source. In hybrid modes, it preserves the existing analog radio programming formats in both the analog and digital transmissions. MPS data or SPS data, also known as program service data (PSD), includes information such as music title, artist, album name, etc. Supplemental program service can include supplementary audio content as well as program service data.
The importer 18 contains hardware and software for supplying advanced application services (AAS). AAS can include any type of data that is not classified as MPS, SPS, or Station Information Service (SIS). SIS provides station information, such as call sign, absolute time, position correlated to GPS, etc. Examples of AAS include data services for electronic program guides, navigation maps, real-time traffic and weather information, multimedia applications, other audio services, and other data content. The content for AAS can be supplied by service providers 44, which provide service data 46 to the importer via an application program interface (API). The service providers may be a broadcaster located at the studio site or externally sourced third-party providers of services and content. The importer can establish session connections between multiple service providers. The importer encodes and multiplexes service data 46, SPS audio 38, and SPS data 36 to produce exporter link data 24, which is output to the exporter via a data link. The importer 18 also encodes a SIG, in which it typically identifies and describes available services. For example, the SIG may include data identifying the genre of the services available on the current frequency (e.g., the genre of MPS audio and any SPS audio).
The importer 18 can use a data transport mechanism, which may be referred to herein as a radio link subsystem (RLS), to provide packet encapsulation, varying levels of quality of service (e.g., varying degrees of forward error correction and interleaving), and bandwidth management functions. The RLS uses High-Level Data Link Control (HDLC) type framing for encapsulating the packets. HDLC is known to one of skill in the art and is described in ISO/IEC 13239:2002 Information technology—Telecommunications and information exchange between systems—High-level data link control (HDLC) procedures. HDLC framing includes a beginning frame delimiter (e.g., ‘0x7E’) and an ending frame delimiter (e.g., ‘0x7E’). The RLS header includes a logical address (e.g., port number), a control field for sequence numbers and other information (e.g., packet 1 of 2, 2 of 2 etc.), the payload (e.g., the index file), and a checksum (e.g., a CRC). For bandwidth management, the importer 18 typically assigns logical addresses (e.g. ports) to AAS data based on, for example, the number and type of services being configured at any given studio site 10. RLS is described in more detail in U.S. Pat. No. 7,305,043, which is incorporated herein by reference in its entirety.
Due to receiver implementation choices, RLS packets can be limited in size to about 8192 bytes, but other sizes could be used. Therefore data may be prepared for transmission according to two primary data segmentation modes—packet mode and byte-streaming mode—for transmitting objects larger than the maximum packet size. In packet mode the importer 18 may include a large object transfer (LOT) client (e.g. a software client that executes on the same computer processing system as the importer 18 or on a different processing system such as a remote processing system) to segment a “large” object (for example, a sizable image file) into fragments no larger than the chosen RLS packet size. In typical embodiments objects may range in size up to 4,294,967,295 bytes. At the transmitter, the LOT client writes packets to an RLS port for broadcast to the receiver. At the receiver, the LOT client reads packets from the RLS port of the same number. The LOT client may process data associated with many RLS ports (e.g., typically up to 32 ports) simultaneously, both at the receiver and the transmitter.
The LOT client operates by sending a large object in several messages, each of which is no longer than the maximum packet size. To accomplish this, the transmitter assigns an integer called a LotID to each object broadcast via the LOT protocol. All messages for the same object will use the same LotID. The choice of LotID is arbitrary except that no two objects being broadcast concurrently on the same RLS port may have the same LotID. In some implementations, it may be advantageous to exhaust all possible LotID values before a value is reused.
When transmitting data over-the-air, there may be some packet loss due to the probabilistic nature of the radio propagation environment. The LOT client addresses this issue by allowing the transmitter to repeat the transmission of an entire object. Once an object has been received correctly, the receiver can ignore any remaining repetitions. All repetitions will use the same LotID. Additionally, the transmitter may interleave messages for different objects on the same RLS port so long as each object on the port has been assigned a unique LotID.
The LOT client divides a large object into messages, which are further subdivided into fragments. Preferably all the fragments in a message, excepting the last fragment, are a fixed length such as 256 bytes. The last fragment may be any length that is less than the fixed length (e.g., less than 256 bytes). Fragments are numbered consecutively starting from zero. However, in some embodiments an object may have a zero-length object—the messages would contain only descriptive information about the object.
The LOT client typically uses two types of messages—a full header message, and a fragment header message. Each message includes a header followed by fragments of the object. The full header message contains the information to reassemble the object from the fragments plus descriptive information about the object. By comparison, the fragment header message contains only the reassembly information. The LOT client of the receiver (e.g. a software and/or hardware application that typically executes within the data processors 232 and 288 of
Full header and fragment header messages may be sent in any ratio provided that at least one full header message is broadcast for each object. Bandwidth efficiency will typically be increased by minimizing the number of full header messages; however, this may increase the time necessary for the receiver to determine whether an object is of interest based on the descriptive information that is only present in the full header. Therefore there is typically a trade between efficient use of broadcast bandwidth and efficient receiver processing and reception of desired LOT files.
In byte-streaming mode, as in packet mode, each data service is allocated a specific bandwidth by the radio station operators based on the limits of the digital radio broadcast modem frames. The importer 18 then receives data messages of arbitrary size from the data services. The data bytes received from each service are then placed in a byte bucket (e.g. a queue) and HDLC frames are constructed based on the bandwidth allocated to each service. For example, each service may have its own HDLC frame that will be just the right size to fit into a modem frame. For example, assume that there are two data services, service #1 and service #2. Service #1 has been allocated 1024 bytes, and service #2 512 b Now assume that service #1 sends message A having 2048 bytes, and service #2 sends message B also having 2048 bytes. Thus the first modem frame will contain two HDLC frames; a 1024 byte frame containing N bytes of message A and a 512 byte HDLC frame containing M bytes of message B. N & M are determined by how many HDLC escape characters are needed and the size of the RLS header information. If no escape characters are needed then N=1015 and M=503 assuming a 9 byte RLS header. If the messages contain nothing but HDLC framing bytes (i.e. 0x7E) then N=503 and M=247, again assuming a 9 byte RLS header containing no escape characters. Also, if data service #1 does not send a new message (call it message AA) then its unused bandwidth may be given to service #2 so its HDLC frame will be larger than its allocated bandwidth of 512 bytes.
The exporter 20 contains the hardware and software necessary to supply the main program service and SIS for broadcasting. The exporter accepts digital MPS audio 26 over an audio interface and compresses the audio. The exporter also multiplexes MPS data 40, exporter link data 24, and the compressed digital MPS audio to produce exciter link data 52. In addition, the exporter accepts analog MPS audio 28 over its audio interface and applies a pre-programmed delay to it to produce a delayed analog MPS audio signal 30. This analog audio can be broadcast as a backup channel for hybrid IBOC digital radio broadcasts. The delay compensates for the system delay of the digital MPS audio, allowing receivers to blend between the digital and analog program without a shift in time. In an AM transmission system, the delayed MPS audio signal 30 is converted by the exporter to a mono signal and sent directly to the STL as part of the exciter link data 52.
The EASU 22 accepts MPS audio 42 from the studio automation equipment, rate converts it to the proper system clock, and outputs two copies of the signal, one digital (26) and one analog (28). The EASU includes a GPS receiver that is connected to an antenna 25. The GPS receiver allows the EASU to derive a master clock signal, which is synchronized to the exciter's clock by use of GPS units. The EASU provides the master system clock used by the exporter. The EASU is also used to bypass (or redirect) the analog MPS audio from being passed through the exporter in the event the exporter has a catastrophic fault and is no longer operational. The bypassed audio 32 can be fed directly into the STL transmitter, eliminating a dead-air event.
STL transmitter 48 receives delayed analog MPS audio 50 and exciter link data 52. It outputs exciter link data and delayed analog MPS audio over STL link 14, which may be either unidirectional or bidirectional. The STL link may be a digital microwave or Ethernet link, for example, and may use the standard User Datagram Protocol or the standard TCP/IP.
The transmitter site includes an STL receiver 54, an exciter engine (exgine) 56 and an analog exciter 60. The STL receiver 54 receives exciter link data, including audio and data signals as well as command and control messages, over the STL link 14. The exciter link data is passed to the exciter 56, which produces the IBOC digital radio broadcasting waveform. The exciter includes a host processor, digital up-converter, RF up-converter, and exgine subsystem 58. The exgine accepts exciter link data and modulates the digital portion of the IBOC digital radio broadcasting waveform. The digital up-converter of exciter 56 converts from digital-to-analog the baseband portion of the exgine output. The digital-to-analog conversion is based on a GPS clock, common to that of the exporter's GPS-based clock derived from the EASU. Thus, the exciter 56 includes a GPS unit and antenna 57. An alternative method for synchronizing the exporter and exciter clocks can be found in U.S. Pat. No. 7,512,175, the disclosure of which is hereby incorporated by reference. The RF up-converter of the exciter up-converts the analog signal to the proper in-band channel frequency. The up-converted signal is then passed to the high power amplifier 62 and antenna 64 for broadcast. In an AM transmission system, the exgine subsystem coherently adds the backup analog MPS audio to the digital waveform in the hybrid mode; thus, the AM transmission system does not include the analog exciter 60. In addition, in an AM transmission system, the exciter 56 produces phase and magnitude information and the analog signal is output directly to the high power amplifier.
IBOC digital radio broadcasting signals can be transmitted in both AM and FM radio bands, using a variety of waveforms. The waveforms include an FM hybrid IBOC digital radio broadcasting waveform, an FM all-digital IBOC digital radio broadcasting waveform, an AM hybrid IBOC digital radio broadcasting waveform, and an AM all-digital IBOC digital radio broadcasting waveform.
The hybrid waveform includes an analog FM-modulated signal, plus digitally modulated primary main subcarriers. The subcarriers are located at evenly spaced frequency locations. The subcarrier locations are numbered from −546 to +546. In the waveform of
The upper primary extended sidebands include subcarriers 337 through 355 (one frequency partition), 318 through 355 (two frequency partitions), or 280 through 355 (four frequency partitions). The lower primary extended sidebands include subcarriers −337 through −355 (one frequency partition), −318 through −355 (two frequency partitions), or −280 through −355 (four frequency partitions). The amplitude of each subcarrier can be scaled by an amplitude scale factor.
In addition to the ten main frequency partitions, all four extended frequency partitions are present in each primary sideband of the all-digital waveform. Each secondary sideband also has ten secondary main (SM) and four secondary extended (SX) frequency partitions. Unlike the primary sidebands, however, the secondary main frequency partitions are mapped nearer to the channel center with the extended frequency partitions farther from the center.
Each secondary sideband also supports a small secondary protected (SP) region 110, 112 including 12 OFDM subcarriers and reference subcarriers 279 and −279. The sidebands are referred to as “protected” because they are located in the area of spectrum least likely to be affected by analog or digital interference. An additional reference subcarrier is placed at the center of the channel (0). Frequency partition ordering of the SP region does not apply since the SP region does not contain frequency partitions.
Each secondary main sideband spans subcarriers 1 through 190 or −1 through −190. The upper secondary extended sideband includes subcarriers 191 through 266, and the upper secondary protected sideband includes subcarriers 267 through 278, plus additional reference subcarrier 279. The lower secondary extended sideband includes subcarriers −191 through −266, and the lower secondary protected sideband includes subcarriers −267 through −278, plus additional reference subcarrier −279. The over-the-air frequency span of the entire all-digital spectrum is 396,803 Hz. The amplitude of each subcarrier can be scaled by an amplitude scale factor. Any one of the four may be selected for application to the secondary sidebands.
In each of the waveforms, the digital signal is modulated using orthogonal frequency division multiplexing (OFDM). OFDM is a parallel modulation scheme in which the data stream modulates a large number of orthogonal subcarriers, which are transmitted simultaneously. OFDM is inherently flexible, readily allowing the mapping of logical channels to different groups of sub carriers.
In the hybrid waveform, the digital signal is transmitted in primary main (PM) sidebands on either side of the analog FM signal in the hybrid waveform. The power level of each sideband is appreciably below the over-the-air power in the analog FM signal. The analog signal may be monophonic or stereophonic, and may include subsidiary communications authorization (SCA) channels.
In the extended hybrid waveform, the bandwidth of the hybrid sidebands can be extended toward the analog FM signal to increase digital capacity. This additional spectrum, allocated to the inner edge of each primary main sideband, is termed the primary extended (PX) sideband.
In the all-digital waveform, the analog signal is removed and the bandwidth of the primary digital sidebands is fully extended as in the extended hybrid waveform. In addition, this waveform allows lower-power digital secondary sidebands to be transmitted in the spectrum vacated by the analog FM signal.
The AM hybrid IBOC digital radio broadcasting signal format in one example comprises the analog modulated carrier signal 134 plus OFDM subcarrier locations spanning the upper and lower bands. Coded digital information representative of the audio or data signals to be transmitted (program material), is transmitted on the subcarriers. The symbol rate is less than the subcarrier spacing due to a guard time between symbols.
As shown in
The power of subcarriers in the digital sidebands is significantly below the over-the-air power in the analog AM signal. The level of each OFDM subcarrier within a given primary or secondary section is fixed at a constant value. Primary or secondary sections may be scaled relative to each other. In addition, status and control information is transmitted on reference subcarriers located on either side of the main carrier. A separate logical channel, such as an IBOC Data Service (IDS) channel can be transmitted in individual subcarriers just above and below the frequency edges of the upper and lower secondary sidebands. The power level of each primary OFDM subcarrier is fixed relative to the unmodulated main analog carrier. However, the power level of the secondary subcarriers, logical channel subcarriers, and tertiary subcarriers is adjustable.
Using the modulation format of
The host controller 240 receives and processes the data signals (e.g., the SIS, MPSD, SPSD, and AAS signals). The host controller 240 comprises a microcontroller that is coupled to the display control unit (DCU) 242 and memory module 244. Any suitable microcontroller could be used such as an 8-bit reduced instruction set computer (RISC) microcontroller, an advanced RISC machine 32-bit microcontroller or any other suitable microcontroller. Additionally, a portion or all of the functions of the host controller 240 could be performed in a baseband processor (e.g., the processor 224 and/or data processor 232). The DCU 242 comprises any suitable I/O processor that controls the display, which may be any suitable visual display such as an LCD or LED display. In certain embodiments, the DCU 242 may also control user input components via touch-screen display. In certain embodiments the host controller 240 may also control user input from a keyboard, dials, knobs or other suitable inputs. The memory module 244 may include any suitable data storage medium such as RAM, Flash ROM (e.g., an SD memory card), and/or a hard disk drive. In certain embodiments, the memory module 244 may be included in an external component that communicates with the host controller 240 such as a remote control.
The following describes exemplary processes for providing an uninterrupted rendering of content at a digital radio broadcast receiver. As described in detail below, certain aspects of these processes are carried out at the transmitter side, while other aspects are carried out at the receiver side. In general, the approaches described herein utilize cross-medium reception techniques, whereby same content is delivered to the digital radio broadcast receiver over two parallel paths. The two parallel paths may comprise two different communication platforms, such as over-the-air digital radio broadcast transmission and wireless Internet. By default, data from a primary communication platform is selected for rendering at the receiver, unless this data contains an error. When such an error is detected, data from a secondary communication medium is selected and rendered. The data from the secondary medium provides corrected, error-free data for providing an uninterrupted rendering of content at the receiver. Although the description below primarily describes the use of this approach for rendering audio, it should be understood that the systems and methods described herein apply to the rendering of any type of content (e.g., any one of audio, video, text, still images, multimedia, etc., or a combination thereof).
A content provider 1110 may supply HD1 audio 1114 to the exporter 1106. The HD1 audio 1114 may be encoded audio configured to be broadcast over-the-air by the transmitter system 1102. The HD1 audio 1114 may include, for example, main program service (MPS) audio and MPS data (e.g., program service data (PSD)) as described in greater detail above with reference to
The importer 1104 may contain hardware and/or software for producing exporter link data 1105, which is output to the exporter 1106 via a data link. To produce the exporter link data 1105, the importer 1104 may encode and multiplex various data (e.g., AAS data, HD2/HD3 audio, and SPS data services, etc.). The importer 1104 may also encode a SIG (service information guide) that identifies and describes available services and provides various other services (e.g., access keys, component priorities data, etc.). The exporter 1106 may contain the hardware and/or software necessary to supply audio and data to the transmitter 1108 for broadcasting. Specifically, the exporter 1106 may receive the HD1 audio 1114 from the content provider 1110 and compress the audio 1114. The exporter 1106 may further multiplex the compressed audio and the exporter link data 1105 to produce exciter link data 1107. The exciter link data 1107 is received at the transmitter 1108, which may utilize an exciter to produce a digital radio broadcasting waveform. The digital radio broadcasting waveform may undergo various processing (e.g., upconversion, amplification, etc.) before being passed to an antenna for broadcast.
The over-the-air digital radio broadcast signal 1140 including audio and/or data may be broadcasted from the antenna of the transmitter 1108 and received by the digital radio broadcast receiver system 1134. In the example of
Digital radio broadcast signals may be subject to intermittent fades or blockages in certain conditions that may result in disruption or degradation of signal strength for signals received at the digital radio broadcast receiver system 1134. These phenomena can result in errors or temporary loss in the broadcast signal 1140 received at the receiver system 1134, preventing the signal data from being decoded and recovered properly. Such signal disruptions may produce noticeable gaps in the reception of the digital broadcast signal. Where available, analog audio received contemporaneously can be automatically blended to fill the gap for MPS audio, but not for SPS audio and not for data services. To further mitigate the effects of such signal disruptions and/or gaps in the reception of the digital broadcast signal, the system of
In an example of the gap-filling system described herein, signals associated with the unique HD Radio broadcasting data structures including audio data are received by the receiver system 1134 over the two communication platforms, where the first platform is over-the-air, digital radio broadcast transmission and the second platform is wireless Internet, and the data of the broadcast signal 1140 are inspected individually for errors. If a data unit, e.g., a HD Radio modem frame or a HD Radio modem block, from the broadcast signal 1140 does not contain an error, then this data unit is selected and rendered at the receiver 1134. In this case, a corresponding data unit (i.e., a frame or a block corresponding to a data structure including audio data that is the same as that included in the over-the-air data structure) received via the wireless Internet is not used. Conversely, if the data unit from the broadcast signal 1140 does contain an error, then the corresponding data unit received via the wireless Internet is selected and rendered at the receiver 1134. The two communication platforms thus function as parallel paths for delivering same audio data to the receiver system 1134, with the audio data of the wireless Internet acting as a piece-by-piece backup source of data in instances where the data of the broadcast signal 1140 contains errors. In situations where both the over-the-air broadcast signal and the Internet connectivity are disrupted, data previously stored at the receiver system 1134, or analog data received contemporaneously, may be rendered to prevent a dead-air event.
As explained above, the second communication platform used in delivering the duplicate data 1130 to the receiver 1134 may be wireless Internet (e.g., WiFi, mobile telecommunications technologies such as 3G, 4G, etc.). To implement the delivery of the duplicate data 1130 in this manner, the importer 1104 and exporter 1106 may upload a multiplicity of files 1116, 1118, respectively, wherein each file contains a data structure, to a storage device 1124 via the Internet 1120. The files 1116, 1118 include data structures that are generated based on the encoded audio and data 1112, 1114 received from the content provider 1110. Thus, the data included in the uploaded files 1116, 1118 originates from the content provider 1110 and is based on the audio and data 1112, 1114 that are intended to be broadcast over-the-air by the transmitter 1102. The storage device 1124 may be a file server associated with an Internet Protocol (IP) address. In an example, all encoded and then formatted in a unique HD Radio broadcast structure audio data that is broadcast via the transmitter system 1102 is also uploaded from the transmitter system 1102 to the storage device 1124. The file server 1124 makes this audio data (in a form of multiple files wherein each file contains a unique HD Radio broadcast structure) available for downloading by the receiver system 1134 (e.g., via wireless Internet communication).
The exemplary baseband processor 251 of
The host controller 296 receives and processes the data signals (e.g., SIS, MPS data, SPS data, and AAS). The host controller 296 comprises a microcontroller that is coupled to the DCU 298 and memory module 300. Any suitable microcontroller could be used such as an 8-bit RISC microcontroller, an advanced RISC machine 32-bit microcontroller or any other suitable microcontroller. Additionally, a portion or all of the functions of the host controller 296 could be performed in a baseband processor (e.g., the processor 280 and/or data processor 288). The DCU 298 comprises any suitable I/O processor that controls the display, which may be any suitable visual display such as an LCD or LED display. In certain embodiments, the DCU 298 may also control user input components via a touch-screen display. In certain embodiments the host controller 296 may also control user input from a keyboard, dials, knobs or other suitable inputs. The memory module 300 may include any suitable data storage medium such as RAM, Flash ROM (e.g., an SD memory card), and/or a hard disk drive. In certain embodiments, the memory module 300 may be included in an external component that communicates with the host controller 296 such as a remote control.
In practice, many of the signal processing functions shown in the receivers of
As shown in
Layer 2 and Layer 1 data in an IBOC system can be considered to be temporally divided into frames (e.g., modem frames). In typical embodiments, each modem frame has a frame duration (Tf) of approximately 1.486 seconds. Each modem frame is noted by and includes (in SIS) an absolute Layer 1 frame number (ALFN), which is a sequential number assigned to every Layer 1 frame that consequently applies to Layer 2. This ALFN corresponds to the broadcast starting time of a modem frame. The start time of ALFN 0 was 00:00:00 Universal Coordinated Time (UTC) on Jan. 6, 1980 and each subsequent ALFN is incremented by one from the previous ALFN. Thus the present time can be calculated by multiplying the next frame's ALFN with Tf and adding the over-the-air to the start time of ALFN 0.
There are multiple Layer 1 logical channels based on service mode, wherein a service mode is a specific configuration of operating parameters specifying throughput, performance level, and selected logical channels. The number of active Layer 1 logical channels and the characteristics defining them vary for each service mode. Status information is also passed between Layer 2 and Layer 1. Layer 1 converts the PDUs from Layer 2 and system control information into an AM or FM IBOC digital radio broadcasting waveform for transmission. Layer 1 processing can include scrambling, channel encoding, interleaving, OFDM subcarrier mapping, and OFDM signal generation. The output of OFDM signal generation is a complex, baseband, time domain pulse representing the digital portion of an IBOC signal for a particular symbol. Discrete symbols are concatenated to form a continuous time domain waveform, which is modulated to create an IBOC waveform for transmission.
As described above, Layer 2 PDUs are routed through the correct logical channels to Layer 1 (338). Layer 2 PDUs are also routed to IP File Encapsulation 350. Specifically,
The selector 702 also receives discrete data units P1-P4 and S1-S5 (712) from a wireless IP interface 708. The data units 712 received via the wireless IP interface 708 originate from a digital radio broadcast transmitter system. Specifically, in providing the data units 712 to the selector 702, the data units 712 are uploaded from the transmitter system to a file server 706. Aspects of this uploading are described below with reference to
The selector 702 is used to select between the data units 710 received over-the-air and the data units 712 received via the wireless IP interface 708. To perform this selection, the selector 702 receives three inputs: the data units 710 received over-the-air, the data units 712 received via the wireless IP interface 708, and selection decisions 722 from an error detector 704. Each of the over-the-air data units 710 is processed individually by the selector 702. If a selection decision 722 from the error detector 704 indicates that the over-the-air data unit does not contain an error, then the selector 702 selects the over-the-air data unit for further processing. In this case, a corresponding data unit from the wireless IP interface 708 is not used and may be deleted from the receiver system. If the selection decision 722 from the error detector 704 indicates that the over-the-air data unit contains an error, then the selector 702 selects the corresponding data unit from the wireless IP interface 708 for further processing. The over-the-air data unit containing the error is not used and may be deleted from the receiver system.
The selector 702 is driven by the selection decisions 722 provided by the error detector 704, with the selection decisions 722 being indicative of whether the over-the-air data units 710 contain errors. The error detector 704 may generate the selection decisions 722 based on signal quality measures 714, 716, 718, 720. As illustrated in
The signal quality measure 714 may be based on a digital signal quality metric (DSQM) determined in the Layer 1 (560). Exemplary digital signal quality metrics are described in U.S. Pat. Nos. 7,933,368 and 8,817,917, for example, which are incorporated herein by reference in their entireties. If the DSQM associated with a data unit received over-the-air is determined to be below a certain threshold level, then the signal quality measure 714 may indicate a Layer 1 error to the error detector 704. Based on the Layer 1 error, the error detector 704 may generate the selection decision 722 that results in the discarding of the over-the-air data unit and the selection of a corresponding data unit received from the file server 706.
The signal quality measure 716 may be based on Layer 2 Protocol Control Information (PCI). Layer 2 PCI is included as part of a Layer 2 PDU for every Layer 1 logical channel and is described in NRSC-5 Reference Document 1014s Rev. I (Layer 2 Channel Multiplex), dated Aug. 23, 2011, which is incorporated herein by reference in its entirety. As described below with reference to
Based on the correlation processes, a sequence i is selected that provides a maximum Mi. The maximum Mi value is compared to a threshold value Mthr. If the maximum Mi value for the over-the-air data unit is at or above the threshold value Mthr, then the signal quality measure 716 may indicate to the error detector 704 that there is no Layer 2 error. Conversely, if the maximum M, for the over-the-air data unit is below the threshold value Mthr, then the signal quality measure 716 may indicate to the error detector 704 that there is a Layer 2 error, thus informing the error detector 704 that the over-the-air data unit contains an error. Based on the Layer 2 error, the error detector 704 may generate the selection decision 722 that results in the discarding of the over-the-air data structure and the selection of the corresponding data unit received from the file server 706.
The signal quality measures 718, 720 may be based on a Reed-Solomon (RS) codeword and cyclic redundancy check (CRC) bytes included in a Layer 4 PDU. The RS codeword and the CRC bytes for audio transport are described in NRSC-5 Reference Document 1017s Rev. G (HD Radio Air Interface Design Description Audio Transport), dated Aug. 23, 2011, and for AAS transport in NRSC-5 Reference Document 1019s Rev. G (HD Radio Air Interface Advanced Application Services Transport), dated Aug. 23, 2011, which are incorporated herein by reference in their entirety. The signal quality measures 718, 720 may be calculated as follows: for each PDU (i.e., each Layer 4 frame) for the currently decoded program, RS error correction is performed, and then the CRC byte is calculated for each packet. If any of these calculations results in an error, then the quality is below the usefulness level, and a Layer 4 error is flagged. The signal quality measures 718, 720 may indicate the Layer 4 error to the error detector 704. Based on the Layer 4 error, the error detector 704 may generate the selection decision 722 that results in the discarding of the over-the-air data unit associated with the Layer 4 frame having the error and the selection of the corresponding data unit received from the file server 706. In an example, the selector 702 is implemented via hardware and/or software in a baseband processor of the receiver system. In one embodiment, the selector 702 is implemented in software written in C code that is executed in the baseband processor.
The selector 702 may demultiplex the selected data structures P1-P4 and S1-S5 to produce SIS PDUs, AAS PDUs, and Stream 0 (core) audio PDUs and Stream 1 (optional enhanced) audio PDUs, as illustrated in
The transmitter system 1204 generates data units, e.g., PDUs, based on the encoded audio 1214. The contents of the data units include audio data configured to be rendered by a digital radio broadcast receiver. As described below, these data units are broadcast over-the-air via a digital radio broadcast transmission and also uploaded to a file server to facilitate downloading of the data units by a receiver system via a secondary platform. In an embodiment, a data unit is a Layer 2 Protocol Data Unit (PDU) described in greater detail below with reference to
As illustrated in
In an example, the storing of the file 1216 on the computing system 1208 comprises an uploading process whereby the file 1216 is uploaded from the transmitter system 1204 to the computing system 1208 over the Internet. The uploading of the file 1216 may utilize an Internet protocol such as Hypertext Transfer Protocol (HTTP), Hypertext Transfer Protocol Secure (HTTPS), File Transfer Protocol (FTP), File Transfer Protocol Secure (FTPS), or Web Distributed Authoring and Versioning (WebDAV), among others. In an example, an exporter of the transmitter system 1204 employs FTP/FTPS for file-by-file upload to the computing system 1208, and a channel multiplexer handler (Layer 2) employs FTP/FTPS for multiple file upload.
Both single service and “all services” files, as shown in
The file 1216 uploaded to the computing system 1208 encapsulating the aforementioned data structure and also includes various naming attributes, a content ID, a call-sign for the station, an expiration time, and a time stamp. The content ID may be an identifier for the content included in the file 1216 (e.g., the content ID may indicate a name of an audio program, a date, etc.). The expiration time may indicate a time after which the file 1216 can be purged (e.g., deleted) from the computing system 1208. The time stamp may indicate a time at which a digital radio broadcast signal including the data structure is transmitted from the transmitter system 1204. Files are queued in the computing system 1208 based on the content ID, the time stamp and the expiration time. A receiver system 1212 may request the file based on attributes of the file: (1) file name or indexed name (any matching file) or multiple names; (2) content ID, where all matching files are sorted by future expiration time; or (3) call-sign, where all matching files are sorted by future expiration time.
The data structure that is encapsulated into the file 1216 and uploaded to the computing system 1208 is also broadcast over-the-air by the transmitter system 1204. Thus, the transmitter system 1204 broadcasts a digital radio broadcast signal 1218 including encoded data corresponding to the data structure for receipt at the receiver system 1212. In an embodiment, after the encapsulation of the data structure into the file 1216, the file 1216 is uploaded to the computing system 1208 contemporaneously with the broadcasting of the signal 1218 including the encoded data for the data structure. As illustrated in
Service Information Guide (SIG) data of the broadcast signal 1218 provides detailed information on the gap-filling service. For example, when “all services” files are available from the computing system 1208, file names index for these files may be indicated in the SIG data. When single service files are available from the computing system 1208, file names index for specific audio programs may be indicated in the SIG data and/or PSD data received by the receiver. The SIG data may also include information on a file naming convention used for the files stored at the computing system 1208. In the systems and methods described herein, files stored at the computing system 1208 may utilize a default naming convention that is known to receivers. In requesting files from the computing system 1208, receivers may utilize the default naming convention. When files at the computing system 1208 have names that differ from the default naming convention, information on the different naming convention may be provided to the receiver via the SIG data.
The SIG data may also include the IP address or URL for the computing system 1208.
A URL for a file or files associated with a specific audio program may be indicated in the audio program's PSD, with the URL being used by the receiver to download the file or files that are located on the computing system 1208. Receivers may also construct a table that associates URLs with station call-signs and use this table for downloading files associated with different stations from the computing system 1208. The URLs included in the table may be “placeholder” URLs that are not the actual URLs for the stations. Thus, a central registry (proxy) server may store pointers that associate the placeholder URLs with the actual URLs. A receiver that is missing URL data for a station may use the call-sign of the station to query the registry for the file server URL for the station.
Based on the station identifier, the receiver system 1304 may generate a download request 1308 that is transmitted to a computing system 1302. The download request 1308 may request from the computing system 1302 one or more files that are associated with the station to which the receiver system 1304 is tuned. Specifically, the download request 1308 may request duplicate audio data that is the same as audio data that is broadcasted from the transmitter system 1306. Based on the download request 1308, files may be downloaded wirelessly from the computing system 1302 to the receiver system 1304 using an Internet protocol, such as HyperText Transfer Protocol (HTTP), HyperText Transfer Protocol Secure (HTTPS), File Transfer Protocol (FTP) or File Transfer Protocol Secure (FTPS). In an embodiment, the receiver system 1304 may include a mobile phone, and the mobile phone may execute a mobile software application program (e.g., a mobile app). The transmitting of the download request and the receiving of the files may be performed based on user input received via the mobile software application program. The files downloaded based on the download request 1308 include individually encapsulated over-the-air broadcasting data structures (e.g., segmented content, with each file being a finite object). Each such individual file (e.g., a finite object) can be individually used by the receiver for gap-filling independently of the presence or absence of other files with encapsulated preceding or following data structure from the broadcasting system 1306, and therefore do not require download continuity and do not comprise a portion of a streaming content transfer.
The conditions under which the download request 1308 is transmitted may vary in different examples. In an example, the download request 1308 is sent shortly after tuning into the station or contemporaneously with the tuning into the station. In this example, the download request is sent without consideration as to whether the encoded data for the data structures of the broadcast signal 1314 include errors. Thus, for every data structure whose encoded data is received over-the-air from the transmitter system 1306, a corresponding file encapsulating a data structure including duplicate audio data is requested by the receiver system 1304 from the computing system 1302. The corresponding data received via the different communication platforms may arrive at the receiver system 1304 at nearly the same times. Each data unit of encoded data received over-the-air from the transmitter system 1306 is processed individually to determine if the data contains a data error. If the data contains the data error, corresponding data downloaded from the computing system 1302 is selected and rendered at the receiver system 1304. If the data received over-the-air from the transmitter system 1306 does not contain a data error, this data is selected and rendered. In this example, in rendering an audio program, audio data for the entire audio program may be received from both the transmitter system 1306 and the computing system 1302.
By contrast, in another example, the download request 1308 is transmitted only after a data error is detected in a data unit of the over-the-air broadcast 1314, and the download request 1308 requests only duplicate audio data for the portion of the broadcast signal 1314 containing the data error. To illustrate aspects of this example, reference is made to
In another example, the download request 1308 is transmitted only after a data error is predicted for future data unit of the over-the-air broadcast 1314, and the download request 1308 requests only duplicate audio data for the future portion of the broadcast signal 1314 containing the data error.
In an example, the download request 1402 requests audio data that corresponds to a period of time in the future. For example, the download request 1402 may request files comprising audio data or other data for no more than the next sixty (60) seconds of a radio broadcast from the station. Although the illustration of
In an example, the download request 1402 is renewed by the receiver system every thirty (30) seconds for as long as the receiver system continues to receive an over-the-air signal from the transmitter. In this example, if the download request 1402 requests audio data for the next sixty (60) seconds of the radio broadcast, then the receiver system is capable of receiving duplicate audio data for filling at most a continuous sixty (60) second gap in the over-the-air signal. The system may thus implement a time-limited gap filler, where continuous gaps in the over-the-air signal longer than 60 seconds are not filled by duplicate audio data from the file server. The time-limited gap filler is not implemented using streaming data from the file server. Rather, the time-limited gap filler is implemented using the downloading of files (i.e., file-based segmented content, where each file is a finite object), as described herein, and the downloading of these files does not comprise a streaming content transfer. It should be understood that as referred to herein, a “gap” may comprise a portion of the over-the-air signal containing data errors or other signal quality problems. The gap may also comprise a period of time in which there are some blockages that sufficiently obscure the broadcast signal from the receiver for periods of time, thereby producing a gap in the reception of the broadcast signal.
The time-limited gap-filling, as described herein, occurs when the digital radio broadcast receiver is tuned to a digital radio broadcast transmitter and receives the over-the-air signal. When the receiver detects errors in data units from the over-the-air signal, it then may implement gap-filling using the downloaded files file-by-file (i.e., object-by-object). When the detection of errors in data units received over-the-air reaches a continuous period of 60 (sixty) seconds, the receiver terminates the over-the-air reception. Thus, the gap-filling is also terminated, and no additional download requests are sent and any remaining files arriving after the termination time are discarded. In this example, the time-limited gap-filling originates (i.e., being triggered by), continues and terminates based on the over-the-air reception of digital radio broadcast signal 1314, and does not depend on the availability of the duplicate data units on the file server 1302, and does not depend on the actual receiving of duplicate data units 1310 from the file server 1302. Thus the time-limited gap-filling does not implement and does not use streaming data from a file server.
In
The file 1406 encapsulating the data structure is uploaded from the transmitter system to the file server using the Internet protocol. As illustrated in
In the example of
At the conclusion of the delay period, data 1414 for rendering is communicated to a content render, where the data 1414 includes the data selected from the file 1406 or the broadcast signal 1410. Although the example of
As illustrated in
In the example of
The use of the delay period as illustrated in
In
After the generation of the data structure, the transmitter system may work in parallel on uploading the data structure to the file server and preparing the same data structure to be encoded and broadcast over-the-air via a broadcast signal 1610. Preparing the data structure to be broadcast over-the-air may require various processing of the data structure, and this processing may result in an amount of time elapsing between the generation of the data structure and the broadcasting of the data structure over-the-air via the broadcast signal 1610. After the broadcast signal 1610 is received at the receiver system, additional time may elapse in demodulating and reconstructing the content of the broadcast signal 1610 at the receiver. Thus, as illustrated in
At the receiver system, the data of the broadcast signal 1610 is processed to determine whether the data contains an error. If the data included in the broadcast signal 1610 does not contain an error, this data is selected for rendering at the receiver system, and the data included in the downloaded file 1606 is not rendered and is deleted from the receiver system. If the data included in the broadcast signal 1610 does contain an error, then the data of the downloaded file 1606 is selected for rendering at the receiver system. In the example of
The example of
During the delay period, the file 1706 may be uploaded from the transmitter system to the file server and also downloaded from the file server to the receiver system. Thus, the delay period delays the broadcasting of the data via the broadcast signal 1710 but does not delay the uploading and downloading of the file 1706. As illustrated in
The transmitting of the download request and the downloading of files from the file server may be transparent to a user of the digital radio broadcast system. Thus, a user may have no knowledge that these steps are being performed, and use of the receiver system may be unchanged from the user's perspective. Similarly, the user may have no knowledge of other steps performed at the receiver (e.g., processing an over-the-air data for errors, selecting between data received over-the-air and data received via wireless Internet, etc.).
In an example, the download request is transmitted after the over-the-air reception begins. For example, if the receiver system does not know the station ID of the station from previous reception, then the receiver system tunes to the station and begins to receive an over-the-air signal from the station. The over-the-air signal from the station includes the station ID, and the receiver system subsequently uses the station ID in generating and/or transmitting the download request. In another example, the transmitting of the download request is performed contemporaneously with the tuning into the station. For example, if the receiver system knows the station ID of the station from previous reception, then the download request can be generated based on the known station ID and transmitted to the file server at the same time as the receiver system is tuning into the station.
At 1810, data of a received over-the-air broadcast signal is processed to determine if the data contains a data error. Although the over-the-air broadcast signal may include encoded data for a plurality of data structures, each of the over-the-air data units of encoded data is processed individually at 1810 to determine if the data contains a data error, for example. If it is determined at 1812 that the over-the-air data does not contain a data error, at 1816, the over-the-air data is selected and subsequently rendered at the receiver system. If a file including the same data was downloaded from the file server, at 1820, the file is deleted. The process may return to 1804, where a subsequent download request is transmitted from the receiver system to the file server 1810. In
If it is instead determined at 1812 that the over-the-air data contains a data error, a determination is made at 1814 as to whether a file including the same data is available at the receiver system. If such a file is available, at 1818, the data from the file is selected and subsequently rendered at the receiver system, and the process may then return to 1804, where a subsequent download request is transmitted from the receiver system to the file server 1810. The transition between rendering data received over-the-air and rendering data received via the files may be “seamless” and not detectable by a human user. Alternatively, a one-time audible (i.e., not seamless) transition may be used. If the file is not available, the process transitions to 1816, and the over-the-air data is selected and rendered, despite the fact that the over-the-air data were previously determined to contain a data error. As explained above, when the step 1816 is reached via the determination at 1814 that the data from the file is not available, the step 1820 (i.e., “delete file”) is not performed. Although measures may be taken to help ensure that files including duplicate audio data are available as needed at the receiver system (e.g., by introducing delays at the transmitter side or the receiver side, etc.), the method of
If it is determined at 1910 that the data unit contains an error, at 1916, a download request is transmitted from the receiver system to a file server. The download request requests a file including a data unit that is the same as the over-the-air data unit determined to contain an error. At 1918, the receiver system attempts to download the file from the file server via a wireless Internet communication platform. A determination is made at 1920 as to whether the file including the data unit is available at the receiver system. If the file is available, at 1922, the data unit from the file is selected and subsequently rendered at the receiver system. If such a file is not available, the process transitions to 1914, and the data unit from the over-the-air broadcast signal is selected and rendered, despite the fact that this data unit was previously determined to contain a data error.
If it is instead determined at 1910 that the data unit from the received over-the-air broadcast signal does not contain an error, at 1914, the over-the-air data unit is selected and subsequently rendered at the receiver system. The process may return to 1908 for processing a subsequent over-the-air data unit.
To implement the method of
The payload portion of the Layer 2 PDU can include audio, data, or a combination of audio and data. The payload may be quantified in units of bytes, and any excess payload that does not constitute a byte is located at the end of the payload. The IP File Encapsulation 350 of
As described below with reference to
In the example systems and methods described herein with reference to
The digital radio broadcast receiver system 1134 may further include the Internet receiver 1136, which is used to receive streaming Layer 2 data 2330 via the Internet 1120. To receive such streaming Layer 2 data 2330, the receiver system 1134 may transmit a notification to the storage device 1124. In this regard, the notification may effectively serve as a download request that enables the streaming Layer 2 data 2330 to be received at the receiver system 1134 from the storage device 1124. As noted above, the terminology “notification” and “download request” may be used interchangeably herein, but the notification need not be formatted as a request for information or data. Rather, the notification may take a variety of forms and/or formats and may be anything that is effective to cause a processing of data. Thus, in the example of
The Layer 2 data 2330 may comprise Layer 2 PDUs generated by a channel multiplex layer of the transmitter system 1102 and may comprise the same data that is included in the digital radio broadcast signal 1140. To implement the delivery of the streaming Layer 2 data 2330 in this manner, the digital radio broadcast transmitter system 1102 may process content (e.g., content from a content provider, such as the content provider 1110 described above with reference to
Using the inter-component communications protocol, the digital radio broadcast transmitter system 1102 sends Layer 2 data 2316, 2318 (e.g., Layer 2 PDUs), also referred to as E2X output, over the Internet 1120 to the storage device 1124. The data included in the Layer 2 data 2316, 2318 originates from the content provider and is based on audio and/or data that are intended to be broadcast over-the-air by the transmitter 1102. The Layer 2 data 2316, 2318 can include bundled modem frames that are transmitted using the same bandwidth (e.g., 96 kbps-144 kbps) as is used for over-the-air transport. In addition, the system can employ framing and formatting of the Layer 2 data 2316, 2318 that is the same as that used for over-the-air transmission from the transmitter system 1102. The transmission of the Layer 2 data 2316, 2318 over the Internet 1120 may use, for example, Transmission Control Protocol/Internet Protocol (TCP/IP) or User Datagram Protocol (UDP).
In an example, all audio and/or data that is broadcast over-the-air via the transmitter system 1102 is also uploaded from the transmitter system 1102 to the storage device 1124 in the Layer 2 data 2316, 2318. The storage device 1124 makes this data available for downloading over the Internet 1120 via a streaming content transfer. This is illustrated in
In one embodiment, the streaming Layer 2 data 2330 is used for gap-filling in a manner similar to the file-based gap filling described above with reference to
As described above, the receiver system 1134 may transition between rendering data of the broadcast signal 1140 and rendering the streaming Layer 2 data 2330. In some embodiments, after transitioning to rendering the streaming Layer 2 data 2330, the receiver system 1134 may further be configured to transition back to rendering data of the broadcast signal 1140. The receiver system 1134 may transition back to rendering data of the broadcast signal 1140 based on a determination, for example, that the broadcast signal 1140 no longer includes data errors. Thus, in an example, while rendering content based on the streaming Layer 2 data 2330 received via the wireless Internet, the receiver system 1134 may monitor the digital radio broadcast signal 1140 that is received at the receiver system 1134. The receiver system 1134 may make a determination that a quality of the digital radio broadcast signal 1140 is sufficient to render content at the receiver system 1134. Based on the determination, the receiver system 1134 may resume rendering of content based on data received via the digital radio broadcast transmission instead of data received via the wireless Internet.
When transitioning between rendering data of the broadcast signal 1140 and rendering the streaming Layer 2 data 2330, the transitions may be seamless and not detectable by a human user. To provide the uninterrupted rendering of content at the receiver system 1134, one or more of the techniques described above with reference to
In another embodiment, the streaming Layer 2 data 2330 is used to extend an effective geographic coverage area of the transmitter 1102. For example, after the digital radio broadcast receiver system 1134 leaves an over-the-air coverage area of the transmitter 1102, the receiver system 1134 may begin to receive the streaming Layer 2 data 2330 via the wireless Internet. The receiver system 1134 may be determined to have left the over-the-air coverage area, for example, based on the receiver system 1134 no longer being able to receive the digital radio broadcast signal 1140 or based on a detection of errors in the broadcast signal 1140 (e.g., as described above with reference to
In an embodiment, after the receiver system 1134 is determined to have left the over-the-air geographic coverage area, a user of the receiver system 1134 may be prompted (e.g., via a display screen of the receiver system 1134) to begin receiving the streaming Layer 2 data 2330 via the wireless Internet. If the user answers affirmatively, the receiver system 1134 begins to download and render the streaming Layer 2 data 2330. In another embodiment, the receiver system 1134 begins to download and render the streaming Layer 2 data 2330 automatically when the receiver system 1134 is determined to have left the over-the-air coverage area, without prompting the user. In either of these embodiments, when receipt of the over-the-air broadcast signal 1140 terminates, the receiver system 1134 may determine an exact point in the content at which the over-the-air broadcast signal 1140 was lost. Consequently, the receiver system 1134 may begin to receive the streaming Layer 2 data 2330 that corresponds to the exact point in the content at which the over-the-air signal 1140 was lost. To receive such streaming Layer 2 data 2330, the receiver system 1134 may transmit a download request to the storage device 1124, where the download request may include an indication of the point in the content at which the over-the-air signal 1140 was lost. Thus, for example, the receiver system 1134 may ensure that the listener does not miss any portion of a radio program or song to which he or she was listening.
In some embodiments, when transitioning between rendering data of the broadcast signal 1140 and rendering the streaming Layer 2 data 2330, the transition may be seamless and not detectable by a human user. To provide the uninterrupted rendering of content at the receiver system 1134, one or more of the techniques described above with reference to
In another example, the receiver system 1134 may begin to receive the streaming Layer 2 data 2330 prior to leaving the over-the-air geographic coverage area of the transmitter system 1102. Thus, in this example, receipt of the streaming Layer 2 data 2330 may begin before the over-the-air signal 1140 is lost at the receiver system 1134. For example, the receiver system 1134 may determine that the receiver system 1134 is near a boundary (e.g., an edge) of the over-the-air coverage area of the transmitter system 1102 and/or that the receiver system 1134 will likely be exiting the over-the-air coverage area. The receiver system 1134 may make this determination based on, for example, global positioning system (GPS) coordinates of the receiver system 1134 and GPS coordinates of the transmitter system 1102. In an example, the transmitter system 1102 may broadcast its geographic location in latitude/longitude coordinates within the digital radio broadcast signal 1140, and the receiver system 1134 may receive and use this information in making the determination described above. For example, based on the geographic location of the transmitter system 1102, the receiver system 1134 may determine the over-the-air coverage area of the transmitter system 1102. Based on the over-the-air coverage area and the GPS coordinates of the receiver system 1134, the receiver system 1134 may calculate a distance between the receiver system 1134 and a boundary of the over-the-air coverage area. If the calculated distance is less than a threshold distance, the receiver system 1134 may make the determination that the receiver system 1134 is near the boundary of the over-the-air coverage area of the transmitter system 1102 and/or that the receiver system 1134 will likely be exiting the over-the-air coverage area.
In another example, the digital radio broadcast receiver 1134 may be configured to monitor (e.g., continuously monitor) signal strength of the digital radio broadcast signal 1140 as well as track the location of the receiver 1134, e.g., via a built in GPS unit or based on GPS data from a proximate device. A processing system of the digital radio broadcast receiver 1134 may collect the GPS location of the receiver 1134 at any point in time and the signal strength of a particular station being received at that point in time, and may send this information back to the computing system 1124 via wireless communication. The computing system 1124 may receive such information regarding signal strength, station, and location information from numerous digital radio broadcast receivers and may aggregate that information to generate a signal strength map for particular stations as a function of geographic location. The information for the signal strength map can be updated by the computing system 1124 on an ongoing basis so as to aggregate information over periods of days, weeks, months or longer. To the extent that changes are made to the broadcast transmission equipment or operating parameters, signal strength map data that is deemed obsolete may be purged by the computing system 1124 so as to provide an updated signal strength map. This signal strength map information can be downloaded by digital radio broadcast receivers via wireless communication over the Internet 1120 and stored in the digital radio broadcast receivers. In some examples, the digital radio broadcast receiver 1134 can use the information of the stored signal strength map to anticipate when a vehicle should anticipate loss of signal based on current position (as well as possibly vehicle speed and/or trajectory) and historical signal strength for the present location in order to make a decision to switch from digital radio broadcast reception for a given station to receiving duplicate content via wireless transmission other than digital radio broadcast transmission. For example, for a given present location, a processing system of the digital radio broadcast receiver 1134 can check whether the historical signal strength for the station being received is below a threshold value, and if so, the processing system can cause the receiver 1134 to switch to receiving duplicate content by wireless transmission other than digital radio broadcast transmission. As another example, the processing system could additionally base that decision on whether the present vehicle speed and trajectory is expected to place the vehicle (for an upcoming predetermined distance, e.g., of 0.1 miles, 0.2, miles, 0.5 miles, etc.) in a region of greater signal strength or lesser signal strength. If the former, the processing system can maintain reception via digital radio broadcast transmission, whereas if the latter, the processing system can switch the receiver's reception to duplicate data received via wireless transmission other than digital radio broadcast transmission.
After making the determination that the receiver system 1134 is near a boundary of the over-the-air coverage area of the transmitter system 1102 and/or that the receiver system 1134 will likely be exiting the over-the-air coverage area, the receiver system 1134 may (i) inform the user that the receiver system 1134 is near the edge of the over-the-air geographic coverage area and/or that the receiver system 1134 will likely be exiting the over-the-air coverage area, and (ii) prompt the user to begin receiving the streaming Layer 2 data 2330 via the wireless Internet. If the user answers affirmatively, the receiver system 1134 may begin to receive and render the streaming Layer 2 data 2330. To receive the streaming Layer 2 data 2330, the receiver system 1134 may transmit a download request to the storage device 1124. In another embodiment, the receiver system 1134 may begin to download and render the streaming Layer 2 data 2330 automatically and without prompting the user. When transitioning between rendering data of the broadcast signal 1140 and rendering the streaming Layer 2 data 2330, the transition may be seamless and not detectable by a human user.
In an example, the broadcast signal 1140 may include an IP address or uniform resource locator (URL) of the storage device 1124. The receiver system 1134 may use the IP address or URL to initiate downloading of the streaming Layer 2 data 2330 from the storage device 1124. For example, the receiver system 1134 may transmit download requests to receive the streaming Layer 2 data 2330 to the IP address or URL specified in the broadcast signal 1140. The inclusion of the IP address or URL in a broadcast signal generated by an over-the-air transmitter is described above with reference to
Although examples described above include, for example, receiving and rendering of the streaming Layer 2 data 2330 based on the receiver system 1134 leaving the over-the-air coverage area or based on the receiver system 1134 being near a boundary of the over-the-air coverage area, in other examples, the use of the streaming Layer 2 data 2330 is entirely unrelated to the reception of the broadcast signal 1140. Thus, a listener may be able to listen to his or her “local” radio station anywhere that the listener can receive the streaming Layer 2 data 2330 (e.g., anywhere the user has an Internet connection). When the streaming Layer 2 data 2330 is used at the receiver system 1134, a display or user interface of the receiver system 1134 may provide a “look” and “feel” to the user that is substantially the same as when the content is being rendered from the broadcast signal 1140. In an example, a user may select a preset station and/or broadcast frequency at the receiver system 1134, and if the receiver system 1134 is not able to receive an over-the-air broadcast signal based on the selection, the receiver system 1134 may automatically begin to download and render streaming Layer 2 data associated with the selection. The user need not know an IP address or URL associated with the streaming Layer 2 data, and from a standpoint of the user, the experience may be indistinguishable from situations where the over-the-air broadcast signal is available. To enable the automatic downloading of the streaming Layer 2 data based on the user's selection, the receiver system 1134 may utilize one or more lookup tables, for example. The one or more lookup tables may be used to identify an appropriate storage device or file server to which a download request should be transmitted, where the download request requests the streaming Layer 2 data associated with the user's selection.
Additionally, although examples above describe first rendering data of the broadcast signal 1140 and then transitioning to rendering the streaming Layer 2 data 2330, in other examples, the receiver system 1134 first renders the streaming Layer 2 data 2330 and then transitions to rendering the broadcast signal 1140. Thus, a listener may initially listen to the radio station associated with the transmitter system 1102 via the streaming Layer 2 data 2330 (e.g., by selecting a station preset or broadcast frequency at the receiver system 1134, as described above), and when the receiver system 1134 enters the over-the-air coverage area of the transmitter system 1102, the receiver system 1134 may begin to receive and render data of the broadcast signal 1140. When transitioning between rendering the streaming Layer 2 data 2330 and rendering the data of the broadcast signal 1140, the transition may be seamless and not detectable by a human user.
In an example, the Internet receiver 1136 is used to receive other data in addition to the streaming Layer 2 data 2330. For example, the Internet receiver 1136 may be used to download a list of radio stations and associated broadcast frequencies. Each radio station of the list may be associated with one or more digital radio broadcast signals that are available to the receiver system 1134 based on a location of the receiver system 1134. For example, based on GPS coordinates of the receiver system 1134, the Internet receiver 1136 may download the list of radio stations and associated broadcast frequencies via the Internet 1120. The list of radio stations may be downloaded from the storage device 1124 or from another storage device based on a notification (e.g., a download request) transmitted from the receiver system 1134, where the notification may include the GPS coordinates of the receiver system 1134. The use of the Internet receiver 1136 to download the list of radio stations may obviate the need for the receiver system 1134 to build the list of stations based on data received over-the-air by the HD Radio receiver 1138.
In other examples, the Internet receiver 1136 may be used to download information from the Internet 1120 that is related to content rendered at the receiver system 1134. For example, based on the digital radio broadcast signal 1140 (e.g., PSD information of the signal 1140) and/or the streaming Layer 2 data 2330, the receiver system 1134 may determine a subject matter of the content rendered at the receiver system 1134, a name of a person associated with the content (e.g., an artist, producer, etc.), a song title associated with the content, or an album title associated with the content. Subsequently, a notification (e.g., a download request) may be transmitted from the receiver system 1134 to a computing system (e.g., the storage device 1124 or a different storage device), where the notification requests data that is related to the determined subject matter, name, song title, or album title. The data that is related to the determined subject matter, name, song title, or album title may comprise various data available via the Internet 1120 (e.g., URL-based content), such as information related to merchandise, information related to concert tickets, an image, a video, or biographical information. The data may be received at the Internet receiver 1136 via wireless Internet based on the notification. Further, the received data may be rendered at the receiver system 1134 in a manner that is synchronized (e.g., time aligned) with the content rendered at the receiver system 1134. Thus, for example, an image of an artist downloaded via the Internet receiver 1136 may be displayed at the receiver system 1134 during a period of time in which a song by the artist is being rendered at the receiver system 1134.
The L2IP encapsulated files 2432 received at the receiver system 1134 may be used to implement gap-filling using one or more of the methods described above with reference to
As described above with reference to
Where available, analog audio received at the receiver system 1134 can be automatically blended to fill gaps in MPS audio of the broadcast signal 1140. Thus, in the example of
In an embodiment, to achieve the seamless transitions, an “audio watermark” timing mechanism may be used. The audio watermark may comprise, for example, time markings added to original audio as the original audio is being encoded (e.g., where the encoding is performed to enable the original audio to be transmitted via the transmitter system 1102). Because the broadcast signal 1140, analog audio, L2IP encapsulated files 2432, and Layer 2 data 2330 may be generated at the transmitter system 1102 based on the encoded audio, the time markings may also be present in the broadcast signal 1140, analog audio, L2IP encapsulated files 2432, and Layer 2 data 2330. In time aligning portions of the content that are generated based on these different sources, the receiver system 1134 may utilize the time markings. The audio watermark timing mechanism may be utilized in any of the embodiments described herein with reference to
The Internet receiver 1136 includes processing circuitry that decodes the streaming Layer 2 data 2330 to generate an audio signal that is used to produce an audio output from a transducer, such as a speaker. The processing circuitry may further decode the streaming Layer 2 data 2330 to generate information that can be shown on a user display or graphical user interface. In addition, the processing circuitry may receive user input from the graphical user interface, and respond to that user input, for example, by extracting requested information from the streaming Layer 2 data 2330 based on the input data. The processing circuitry of the Internet receiver 1136 may include, for example, the processing elements of FIG. 12 of U.S. Pat. No. 8,041,292, which is incorporated herein by reference in its entirety.
The information generated based on the streaming Layer 2 data 2330 that may be shown on the user display or graphical user interface may include radio station call letters for a radio station associated with the transmitter system 1102; a slogan of the radio station; a logo of the radio station; the HD channel that is currently being accessed by the user (e.g., “HD1,” “HD2,” etc.); a song title and artist associated with the audio signal generated based on the streaming Layer 2 data 2330; a news stream (e.g., text of a news headline that may scroll across the user display or graphical user interface, stock information, etc.); and a plurality of buttons that may allow the user to (i) select a different HD channel, (ii) to tag the received content; (iii) to request traffic information; (iv) to request weather information; and (v) to request gas prices. When the user presses one of these buttons, the processing circuitry of the Internet receiver 1136 retrieves the requested content or information from the received data 2330 and produces an appropriate output for the speaker and/or user interface.
Other controls implemented via the user display or graphical user interface allow the user to begin receiving streaming Layer 2 data of a different radio station, increase or decrease the volume of the audio output, select between main or secondary programs of the radio station associated with the transmitter system 1102, respond to received data, utilize an electronic program guide, or utilize a store-and-replay functionality of the Internet receiver 1136, for example. Such controls may be implemented using buttons, switches, and other activation mechanisms, either alone or in combination with a software-implemented graphical user interface.
The Internet receiver 1136 may include a processor that unbundles the streaming Layer 2 data 2330 and processes upper layers of audio/data transports. Application specific modules can be provided to support CCU traffic, BTC apps, etc. The Internet receiver 1136 may utilize, for example, an upper layer processor to manage modem frame demultiplexing and audio/data transports. Additionally, the Internet receiver 1136 may include a software application that unbundles these services into a graphical user interface that looks like a typical HD Radio receiver. This allows a user to identify bundled applications such as multicast audio, station identifications, journal line news, traffic/weather, synchronized album art, and synchronized PSD. Although
While the disclosure has been described in detail and with reference to exemplary embodiments thereof, it will be apparent to one skilled in the art that various changes and modifications can be made therein without departing from the spirit and scope of the embodiments. Thus, it is intended that the present disclosure cover the modifications and variations of this disclosure provided they come within the scope of the appended claims and their equivalents.
Claims
1. A computer-implemented method for rendering content at a digital radio broadcast receiver system, the method comprising:
- receiving a digital radio broadcast signal via digital radio broadcast transmission, the digital radio broadcast signal comprising data in a specified format for rendering content at the digital radio broadcast receiver;
- processing the digital radio broadcast signal to determine whether the data from the digital radio broadcast transmission contains a data error and identifying a portion of the data containing the data error;
- transmitting a first notification to a computing system, the first notification being effective to cause the processing of duplicate data for the portion of the data containing the data error,
- receiving the duplicate data at the digital radio broadcast receiver for the portion of the data containing the error via other wireless communication other than the digital radio broadcast transmission based on the first notification, wherein the duplicate data comprises the data in the specified format of the digital radio broadcast signal transmitted by the digital radio broadcast transmitter system; and
- selecting the duplicate data instead of selecting the portion of the data that contains the data error to provide corrected data, and processing the corrected data at the digital radio broadcast receiver to provide an uninterrupted rendering of the content.
2-54. (canceled)
Type: Application
Filed: Sep 27, 2016
Publication Date: Jan 19, 2017
Inventors: Marek Milbar (Huntington Valley, PA), Ashruf S. El-Dinary (Clarksville, MD), Jason K. Carlock (Rochester Hills, MI), Jeffrey Jury (Ellicott City, MD), Jeffrey R. Detweiler (Ellicott City, MD), Timothy L. Tenniswood (Grand Blanc, MI), James DeRidder (Fenton, MI)
Application Number: 15/277,481