Audio content streams are commonly provided by broadcast sources. For instance, Amplitude Modulated (AM) and Frequency Modulated (FM) radio stations have been in existence for this and most of the previous century. More recently, other types of audio broadcast sources have become available such as satellite radio, Internet radio, and digital radio. Some of these broadcast sources are limited to a particular geographical range as the broadcast signal tends to diminish in strength with distance from the broadcast transmitter.
It is common that within a given geographical region, there may be multiple broadcast sources available for a given audio content stream. For instance, consider an audio feed from a live sporting event. Often, one can obtain the same audio feed from both an AM radio station and an FM radio station. If the quality of the received audio signal from the current station diminishes, then the user might search for other stations, if any, that provide the same audio content stream.
There are regions in the world in which radio stations not only broadcasts an audio content stream, but also broadcast associated metadata that definitively identifies the audio content stream. For instance, many European radio stations employ a Radio Data Systems (or RDS) protocol in which some digital information is embedded within conventional FM radio broadcasts. However, much of the world still does not use such broadcast protocols. Furthermore, the digital information identifying the audio content is not continuously transmitted at every instant for every radio station, and thus using that information to always know alternative sources is much more than a trivial problem even in that setting.
The subject matter claimed herein is not limited to embodiments that solve any disadvantages or that operate only in environments such as those described above. Rather, this background is only provided to illustrate one exemplary technology area where some embodiments described herein may be practiced.
At least some embodiments described herein refer to the automated switching of broadcast sources of an audio content stream based on the geographic location of the physical unit that is receiving the audio content stream. For instance, while rendering a particular audio content stream from a first broadcasting source, a system may have an identity of one or more alternative possible broadcasting sources available for the same audio content stream for that relative geographic location. In response to some decision making, the system may decide to switch broadest sources for that audio content stream.
Thus, the user continues to listen to the audio content stream without being subject to possible negative consequences of continuing to listen to the audio content stream as received from the original broadcast station. Furthermore, since geographic location is used to determine available broadcast sources for the same audio content stream, data transmitted by the broadcast stations themselves need not be relied upon. Thus, the automated switching is accomplished even outside of regions in which broadcast stations transmit such geographic data.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
In order to describe the manner in which the above-recited and other advantages and features of the invention can be obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
At least some embodiments described herein include the automated switching of broadcast sources of an audio content stream based on the geographic location of the receiver of the physical unit that is receiving the audio content stream. For instance, while rendering a particular audio content stream from a first broadcasting source, a system may have an identity of one or more alternative possible broadcasting sources available for the same audio content stream for that relative geographic location. In response to some decision making, the system may decide to switch broadest sources for that audio content stream.
For instance, while listening to an audio feed from a particular live sporting event on a particular Amplitude Modulated (AM) radio station, the system may determine that there is another AM radio station available, and another FM station that are broadcasting the same audio feed. This determination is independent of any metadata describing the audio feed transmitted by the radio stations itself, and thus the determination may be made outside of regions in which such metadata is transmitted. Thus, the user continues to enjoy the audio feed from the particular sporting event uninterrupted by potential negative side effects of staying with the same AM radio station, and without having to manually find another replacement station once the negative side effects came into play.
Thus, the user continues to listen to the audio content stream without being subject to possible negative consequences of continuing to listen to the audio content stream as received from the original broadcast station. Furthermore, since geographic location is used to determine available broadcast sources for the same audio content stream, data transmitted by the broadcast stations themselves need not be relied upon. Thus, the automated switching is accomplished even outside of regions in which broadcast stations transmit such data.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the described features or acts described above, or the order of the acts described above. Rather, the described features and acts are disclosed as example forms of implementing the claims.
Computing systems are now increasingly taking a wide variety of forms. Computing systems may, for example, be handheld devices, appliances, laptop computers, desktop computers, mainframes, distributed computing systems, or even devices that have not conventionally been considered a computing system. In this description and in the claims, the term “computing system” is defined broadly as including any device or system (or combination thereof) that includes at least one physical and tangible processor, and a physical and tangible memory capable of having thereon computer-executable instructions that may be executed by the processor. A computing system may be distributed over a network environment and may include multiple constituent computing systems.
As illustrated in
As used herein, the term “executable module” or “executable component” can refer to software objects, routings, or methods that may be executed on the computing system. The different components, modules, engines, and services described herein may be implemented as objects or processes that execute on the computing system (e.g., as separate threads).
In the description that follows, embodiments are described with reference to acts that are performed by one or more computing systems. If such acts are implemented in software, one or more processors of the associated computing system that performs the act direct the operation of the computing system in response to having executed computer-executable instructions. For example, such computer-executable instructions may be embodied on one or more computer-readable media that form a computer program product. An example of such an operation involves the manipulation of data. The computer-executable instructions (and the manipulated data) may be stored in the memory 104 of the computing system 100. Computing system 100 may also contain communication channels 108 that allow the computing system 100 to communicate with other message processors over, for example, network 110.
Embodiments described herein may comprise or utilize a special-purpose or general-purpose computer system that includes computer hardware, such as, for example, one or more processors and system memory, as discussed in greater detail below. The system memory may be included within the overall memory 104. The system memory may also be referred to as “main memory”, and includes memory locations that are addressable by the at least one processing unit 102 over a memory bus in which case the address location is asserted on the memory bus itself. System memory has been traditional volatile, but the principles described herein also apply in circumstances in which the system memory is partially, or even fully, non-volatile.
Embodiments within the scope of the present invention also include physical and other computer-readable media for carrying or storing computer-executable instructions and/or data structures. Such computer-readable media can be any available media that can be accessed by a general-purpose or special-purpose computer system. Computer-readable media that store computer-executable instructions and/or data structures are computer storage media. Computer-readable media that carry computer-executable instructions and/or data structures are transmission media. Thus, by way of example, and not limitation, embodiments of the invention can comprise at least two distinctly different kinds of computer-readable media: computer storage media and transmission media.
Computer storage media are physical hardware storage media that store computer-executable instructions and/or data structures. Physical hardware storage media include computer hardware, such as RAM, ROM, EEPROM, solid state drives (“SSDs”), flash memory, phase-change memory (“PCM”), optical disk storage, magnetic disk storage or other magnetic storage devices, or any other hardware storage device(s) which can be used to store program code in the form of computer-executable instructions or data structures, which can be accessed and executed by a general-purpose or special-purpose computer system to implement the disclosed functionality of the invention.
Transmission media can include a network and/or data links which can be used to carry program code in the form of computer-executable instructions or data structures, and which can be accessed by a general-purpose or special-purpose computer system. A “network” is defined as one or more data links that enable the transport of electronic data between computer systems and/or modules and/or other electronic devices. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer system, the computer system may view the connection as transmission media. Combinations of the above should also be included within the scope of computer-readable media.
Further, upon reaching various computer system components, program code in the form of computer-executable instructions or data structures can be transferred automatically from transmission media to computer storage media (or vice versa). For example, computer-executable instructions or data structures received over a network or data link can be buffered in RAM within a network interface module (e.g., a “NIC”), and then eventually transferred to computer system RAM and/or to less volatile computer storage media at a computer system. Thus, it should be understood that computer storage media can be included in computer system components that also (or even primarily) utilize transmission media.
Computer-executable instructions comprise, for example, instructions and data which, when executed at one or more processors, cause a general-purpose computer system, special-purpose computer system, or special-purpose processing device to perform a certain function or group of functions. Computer-executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, or even source code.
Those skilled in the art will appreciate that the principles described herein may be practiced in network computing environments with many types of computer system configurations, including, personal computers, desktop computers, laptop computers, message processors, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile telephones, PDAs, tablets, pagers, routers, switches, and the like. The invention may also be practiced in distributed system environments where local and remote computer systems, which are linked (either by hardwired data links, wireless data links, or by a combination of hardwired and wireless data links) through a network, both perform tasks. As such, in a distributed system environment, a computer system may include a plurality of constituent computer systems. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
Those skilled in the art will also appreciate that the invention may be practiced in a cloud computing environment. Cloud computing environments may be distributed, although this is not required. When distributed, cloud computing environments may be distributed internationally within an organization and/or have components possessed across multiple organizations. In this description and the following claims, “cloud computing” is defined as a model for enabling on-demand network access to a shared pool of configurable computing resources (e.g., networks, servers, storage, applications, and services). The definition of “cloud computing” is not limited to any of the other numerous advantages that can be obtained from such a model when properly deployed.
The physical system 210 also includes a geographical data source 214 and a logic component 215 that function to facilitate embodiments described further below with respect to
There is no physical restriction on the form of the physical system 210. For instance, the physical system 210 might be a portable radio, in which case perhaps the receiver 211, the tuner 212 and the audio renderer 213 are integrated within the same device. The physical system 210 might alternatively be a vehicle in which case perhaps the receiver 211, the tuner 212, the audio renderer 213 and/or the geographic location determination unit 216 might be somewhat more distributed throughout different parts of the vehicle. Alternatively, the physical system 210 might be quite distributed, with the receiver 211 and the audio renderer 213 perhaps even being remotely located.
Regardless of whether the receiver 211, tuner 212 and the audio renderer 213 is integrated into the same device or vehicle, or are more distributed, the data source 214 may be local to the audio renderer 213, remote from the audio renderer 213, or some combination. For instance, all or part (or none) of the data source 214 might be remotely located from the receiver 211. For instance, the data source 214 might be completely or partially located in a storage service within a cloud computing system. Alternatively or in addition, some or all of the data source might be a peer in a peer-to-peer network. Likewise, the logic unit 215 may be local to the audio renderer 213, remote from the audio renderer 213 or some combination. For instance, all or part (or none) of the logic unit 215 might be located in a compute service within a cloud computing system.
In this particular example, the environment 200 includes eight broadcast sources 201 through 208. A broadcast source includes any source of an analog and/or digital audio content stream. Examples of types of audio broadcasting sources include Amplitude Modulation (AM) stations, Frequency Modulation (FM) stations, digital radio stations, satellite radio channels, and an Internet radio channels. The ellipses 209 represents that there might be any number of audio broadcast sources available to the receiver 211 of the physical system 210. For instance, in populated areas, there are typically dozens of AM radio stations and FM radio stations available to a radio receiver.
The eight broadcast sources 201 through 208 represent sources that the tuner 212 is configured to tune to. For instance, in cases of the broadcast sources 201 through 208 being free of charge, the tuner might have no restriction on tuning to any broadcast source that the receiver 211 is capable of receiving at sufficient signal strengths. On the other hand, there may be reason for imposing policy on which broadcast sources are going to be made available to the tuner 212 given the current geographical region. For instance, subscription-based broadcast sources might be restricted in certain regions, even if it is physical possible for the receiver 211 to receive the broadcast at sufficient strength. In other cases, some broadcast sources may have no geographical restriction imposed at all, and may be received everywhere in the globe (such as Internet radio).
In the example of
The illustrated method 300 includes tuning the audio content stream from a particular broadcasting source (act 301). For instance, in the context of
In response, the audio renderer (e.g., a speaker) begins rendering the audio content stream (act 302). For instance, in
The physical system 210 also identifies a current geographic location (act 303) of the receiver 211. If the physical system 210 is an integrated system such as a radio or a vehicle, the current geographic location of the receiver 211 is the same as that of the physical system 220 as a whole. As previously mentioned, the physical system 210 includes a geographic location determination unit 216 to help determine the current geographic location of the receiver 211. An example is a Global Positioning System (GPS), but other mechanisms may be used to determine current location such as radio tower triangulation.
The physical system 210 (e.g., perhaps the logic unit 214) also identifies one or more alternative broadcasting sources for the audio content stream based on the current geographical location (act 304). For instance, in the environment 200, there happen to be two other alternative audio broadcasting sources 202 and 203, which are also transmitting the same audio content stream A that the listener 225 is currently listening to.
The acts 303 and 304 are illustrated in parallel with acts 301 and 302. This is to emphasize that the available alternatives of given audio broadcasting source may in advance, and/or concurrent with the listener 225 actually listening to the audio content stream from one of the alternatives.
While still rendering the original audio content stream (begun in act 302), the physical system selects (act 305) a next broadcasting source that is to be switched to as a source for the audio content stream. Referring to
As part of this process, the logic unit may have accessed the data source 214. For instance, upon determining what the current geographic location is (act 303), the logic unit 215 may access the data source 214, which may have an entry for each of multiple geographic locations.
For instance, the multiple sets 410 includes set 411 that includes an identity 1 through 3 (corresponding to respective broadcasting sources 201 through 203), set 412 that includes identity 4 and 5 (corresponding to respective broadcasting sources 204 and 205), set 413 that includes identity 6 (corresponding to broadcasting source 206), set 414 that includes identity 7 (corresponding to broadcasting source 207), and set 415 that includes identity 8 (corresponding to broadcasting source 408).
Thus, suppose that location of receiver 211 of
The logic unit 214 might take more affirmative action to actually verify that while act 302 is being performed (audio content stream A is being rendered by tuning to audio broadcast source 201), that the alternative broadcasting sources 202 and 203 are indeed also broadcasting audio content stream A. For instance, the logic unit 214 might very quickly tune to the other audio broadcast source 202 and 203, and capture a small audio sample from the alternative source, perform analysis of the small audio sample, and determine whether the small audio sample matches any portion of what is being tuned to in act 301. The time that the tuner temporarily switches to the alternative audio broadcasting sources 202 or 203 may be kept small enough not to be noticed by a human listener. If the first performance of this brief tuning switch is not enough to conclusively determine whether the audio content streams are the same (e.g., perhaps there happened to be a small period of silence in the alternative broadcasting source 202 and 203 in the small window of time), the process may be repeated, until a sample or samples are captured for a conclusive determination to be made. If a second tuner was available, the logic unit 214 might simply use that second turner to tune to the other audio broadcast source 202 and 203, while allowing the first tuner to continue being tuned to the original audio broadcast source 201.
Thus, once the corresponding set of the geographic entry 400 is accessed, the entry 500 for each of the alternative audio broadcast sources may be evaluated to determine (based on typical previously-measured signal strength in that region, based on whether or not conditions are right for the alternative to be a likely alternative source for the same audio content stream, what the cost of use of the audio content stream is, or based on any other parameters included within the entry) which of the alternative audio broadcast sources should be the next audio broadcast source for the same audio content stream (act 305).
The logic unit 314 might also consider a direction of movement in deciding an appropriate next audio broadcast source to switch to. For instance, suppose that the user is moving towards another geographic location defined within another entry 500. That entry 500 will have different sets of common potential sources of audio content streams. The logic unit may evaluate alternatives for the same audio content stream (e.g., stream A) in the next geographic region as well. The logic unit 214 may thus balance what the best next alternative audio broadcast source for the same audio content stream is in the current geographic location against what the best next alternative audio broadcast source for the same audio content stream is in the next geographic location.
In predicting where the receiver is moving to, the receiver might use simply the direction of movement, statistical prediction based on prior movement, and/or might use a current calculated path on a navigation system. For instance, if the user is generally moving north-easterly, the logic unit might scan the entry 500 for the next region to the northeast. If the user has been travelling on a highway for a long period of time, the logic unit might scan the entry 500 for the next region along that highway. If the user is being guided by a navigation system along a calculated route, the logic unit might scan the entry 500 for the next region along that route.
The granularity for how a geographical region is defined might correspond generally to the gradient of change with distance of signal strength. For instance, in canyons where signals are often blocked by natural terrain, or in urban areas where signals are often blocked by man-made structures, the geographical definitions may define much smaller areas since small movements may make a greater difference on the available options for alternative audio broadcast sources. In other areas, a geographical region may be defined in terms of hundreds of square miles or kilometers.
Once the next audio broadcast source is selected (act 305), the physical system transitions (act 306) the rendering so that the audio content stream is received from the next audio broadcast source. For instance, in the context of
There are numerous ways to perform this transition. The most straightforward way is to simply switch the tuner 212 to the next audio broadcast source discretely after determining that the switch should be made. This can, however, result in the user noticing the change. There are more nuanced ways of making this transition, however, that may result in a less jarring experience for the user.
For instance, suppose that audio content stream A is being delivered from audio broadcast source 201 three seconds ahead of the audio content stream A as delivered from the audio broadcast source 202. A straight switch would be perceived by the listener as re-listening to the same three seconds of feed twice. If the current audio broadcast source 201 is being listened to in delayed mode by more than three seconds, then the switch may happen immediately except that the next broadcast source 202 is begun with three seconds less delay. Another way to handle this if there is no delay in the current audio broadcast source 201 is to make the switch when 3 seconds of silence or a commercial is observed in the audio broadcast source 202. The listener would simply miss that three seconds of silence, or commercial.
Alternatively, suppose that audio content stream A is being delivered from audio broadcast source 201 three seconds behind the audio content stream A as delivered from the audio broadcast source 202. A straight switch would be perceived by the listener as skipping three seconds into the future, with three seconds of the audio content stream being missed. The logic unit 214 might account for this by buffering three seconds worth of the audio broadcast stream A from audio broadcast source 202 while still allowing the listener to listen to the audio broadcast stream A from the audio broadcast source 201, and then switch to the audio broadcast source 202 in a manner as to be three seconds delayed from what otherwise would be heard from the audio broadcast source 202.
When transitioning (act 306) to the next audio broadcast source may also be performed by smoothing any audio characteristics between the current and next audio broadcasting sources. For instance, if it appears that the volume of the next audio broadcasting source is higher than the current audio broadcasting source, the logic unit 214 may automatically cause the audio renderer 213 to adjust down the volume and equivalent amount at the same time as the tuner 212 tunes to the next audio broadcast source, so that the listener does not observe a difference in volume when the switch occurs. As another example, if it appears that the audio frequency of the next audio broadcasting source is different (perhaps has more bass) than the current audio broadcasting source, the logic unit 214 may automatically cause the audio renderer 213 to adjust the audio frequency balance at the same time as the tuner 212 tunes to the next audio broadcast source, so that there is no overall change in audio frequency balance detected by the listener.
Accordingly, a mechanism for automated switching of audio broadcast sources is described in which the user is permitted to listen to the same audio content stream.
There might be a large group of physical systems similar to the one described with respect to physical system 210 of
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.