This patent application describes sharing media content among families of broadcast stations.
Different radio stations have access to different content.
Some radio stations are part of groups of affiliated stations, referred to as families. A family may include radio stations in the same physical vicinity; e.g., within the same city or town. Radio stations in a family may have access to media content of other radio stations in the family. Media content may include, but is not limited to, any type of broadcast content, such as individual songs, playlists, talk radio programming, text, images, and advertising.
This patent application describes sharing media content among families of broadcast stations. For example, according to the implementations described herein, a radio station in one family may search for, and retrieve, media content, such as songs and advertisements, maintained by another radio station family.
In general, this patent application describes sharing media content among families of broadcast stations. A method for sharing media content comprises receiving information relating to media content from families of broadcast stations, storing the information such that the information is accessible to at least two of the families of broadcast stations via a computer network, and receiving a query for specific media content from a broadcast station that is a member of a first family of broadcast stations. The specific media content may be associated with a second family of broadcast stations that is different from the first family. The method also comprises searching the stored information in accordance with the query to identify the specific media content, and enabling the broadcast station to access the specific media content if the specific media content is identified among the stored information. The method may also include one or more of the following features, either alone or in combination.
The information may identify media content by family of broadcast station and by one or more attributes of the media content. The one or more attributes may comprise at least one of a title associated with the media content an artist associated with the media content, notes associated with the media content, a composer associated with the media content, a producer associated with the media content, a category associated with the media content, a type number associated with the media content, an advertiser number associated with the media content, and user-defined eastern information.
The method may comprise generating a graphical user interface (GUI) comprising one or more fields. The query may correspond to information contained in the one or more fields of the GUI. The GUI may comprise one or more options for accessing the specific media content. Enabling the broadcast station to access the specific media content may comprise receiving a selection corresponding to the one or more options, and instructing a broadcast station that stores the specific media content to provide the specific media content to the broadcast station that issued the query. The one or more options may comprise an option to obtain the specific media content immediately, and an option to obtain the media content at a predefined time. The media content may comprise music from a family of broadcast stations or any other media asset. The media content may be stored in one or more repositories that are communicatively coupled to the network.
The broadcast stations may be radio stations. The method may be performed at one or more computer systems that are separate from the families of broadcast stations.
In general, this patent application also describes a method of sharing media content among families of broadcast stations, which comprises receiving information relating to media content for families of broadcast stations, storing the information such that the information is accessible to at least one of the families of broadcast stations via a computer network, and receiving a query for specific media content from a broadcast station that is a member of a first family of broadcast stations. The specific media content may be associated with a second family of broadcast stations that is different from the first family. The method may also comprise searching the information in accordance with the query to identify a location of the specific media content, obtaining the specific media content from the location, and providing the specific media content to the broadcast station. The method may also include one or more of the following features, either alone or in combination.
The method may comprise generating a GUI comprising one or more fields. The query may correspond to information contained in the one or more fields of the GUI. The method may be performed at a central server and the location of the specific media content may comprise one or more servers that are remote from the central server. The one or more servers may be communicatively coupled to the central server via one or more computer networks. The method may be performed at one or more computer systems that is a member of the second family. The broadcast stations may be radio stations. The method may also include receiving other media content from another broadcast station among the families of broadcast stations, and screening the other media content in accordance with one or more predefined rules and/or changing metadata associated with the other media content.
The general and specific aspects can be implemented using a system, method, or a computer program, or any combination of systems, methods, computing devices, and computer programs. The details of one or more implementations arc set forth in the accompanying drawings and the description below. Other features, aspects, and advantages will be apparent from the description, the drawings, and the claims.
Like reference symbols in the various drawings indicate like elements.
Audio content (e.g., music and advertising) may be inventoried and categorized for the communication system 100 in several ways (e.g., by keyword, price, vendor, last played, etc.). Several radio stations can use the communication system 100 and may wish to have access to inventoried media content to schedule music, advertisement, and/or any other type of media asset on their stations. In some implementations, radio stations may use the communication system 100 to share media content. For example, a program director at one radio station may search for and download a song or an advertisement (ad) stored at another radio station. In other implementations, the radio stations, the broadcasting hub, or a combination of the two may use the media content inventory information and other data to un-schedule current programming, and reschedule new programming that may be more suitable (e.g., suitable in terms of content, price, or other criteria) in a particular time slot. For example, a radio station may receive a last minute ad at a higher price (e.g., cost per thousand (CPM)) than other previously received advertisements, and can “bump” (or pre-empt) a currently scheduled advertisement in favor of the higher priced advertisement. In another example, a radio station may receive a new popular song that is deemed worthy of interrupting current programming for immediate play. In some implementations, communication system 100 may allow radio stations to share audio clips of historical significance, such as a press conference describing a new invention that promises to change the world.
As shown in
The network 102 is shown communicatively coupled to third-party data sources 104. Third-party data sources 104 can include any database, data mart, or other data source that provides data of interest to the subscriber 106, the hub 110, or the regional broadcast studio 108 that may be relevant to the content and scheduling of music and advertisements. For example, third-party data may include Arbitron ratings and demographic breakdowns for each station in a broadcast network. Such data may be of use to a subscriber 106 in deciding what amount that the subscriber would be willing to pay to run an advertisement campaign on a given station. In another example, third-party data may indicate the categories of music that are likely to attract listeners in particular areas. Third-party data may categorize music by type (e.g., rock, classical, jazz) and language (e.g., English, Spanish, French). In addition, third-party data may include the weather forecast, current weather conditions, or news events such as stock prices, sports scores, data from a syndicated data feed such as an RSS feed, or any other data relevant to a party's desire to play music or an advertisement. In one implementation, information or data is received or collected directly by the broadcasting hub 110 rather than from third-party sources 104. Regardless of the source, the broadcasting hub 110 can use the information in evaluating whether criteria are met for playing music or an advertisement.
The subscriber 106 is also communicatively coupled to the broadcasting hub 110. This allows the subscriber 106 to purchase, schedule, and upload music and advertising spots using, e.g., a graphical user interface (GUI), of the broadcasting hub 110. Subscriber 106 may access hub 110 via a connection to the network 102. The connection to network 102 may be any connection that allows access to hub 110. For example, subscriber 106 may access hub 110 using TCP/IP and a dial-up connection over a modem, or a dedicated connection that provides constant access. The broadcasting hub 110 may have a unique HyperText Transfer Protocol (HTTP) address, a unique File Transfer Protocol (FTP) address, or any other addressing scheme that allows subscriber 106 to identify hub 110. Subscribers 106 can include music warehouses, advertisers, agencies, stations, or any other entity that interacts with the broadcasting hub 110. In some implementations, subscribers 106 have an account with the broadcasting hub 110 and are charged a fee for use of the broadcasting hub 110. In other implementations, subscribers 106 can access the broadcasting hub 110 free of charge.
As shown in
The regional broadcast studio 108 can also include a programming system 120 that produces and describes the overall broadcast content on a radio station. The programming system 120 can be monitored automatically via a network, such as network 102, and may fee communicatively coupled to the traffic system 114. For example, a program director at a radio station can use the programming system 120 to access media content 116 and playlists 118.
The regional broadcast studio 108 can also include an automation system 122. The automation system 122 enables automatic handling (e.g., producing, storing, sending, receiving) of media content 116 and playlists 118. In one implementation, the automation system 122 can be distributed to include a local portion that is associated with a regional broadcast studio 108 and a remote portion that is associated with broadcasting hub 110. The automation system 122 may be communicatively coupled to the traffic system 114 and the programming system 120.
The regional broadcast studio 108 can also include a multi-station media controller 124. The regional broadcast studio 108 may use the controller 124 to share media content between one or more other radio stations. The multi-station media controller 124 may be communicatively coupled to systems 114, 120 and 122. The multi-station media controller 124 can include a media content finder application 126. The application 126 can allow a user (e.g., a program director) to search for and download media content 116 that maybe stored remotely, such as at another radio station.
The regional broadcast studio 108 is communicatively coupled to the broadcasting hub 110, such that the broadcasting hub 110 is capable of forwarding audio advertisements and musical (or other) content to the regional broadcast studio 108 for play. Thus, the subscriber 106 is capable of submitting media content 116 to the broadcasting hub 110. The media content 116 can include music and advertisements for play along with specific criteria for the play of that music and/or advertisement, and the broadcasting hub 110 can forward the media content to a regional broadcast studio 108 for play as appropriate. In some implementations, the playlists 118 and media content 116 can be stored locally at the regional broadcast station 108.
A broadcasting company may own several radio stations throughout the world, such as in multiple cities throughout North America and other continents. The broadcasting company may want to share media content (or media assets) among these radio stations even though the stations are geographically distributed. For instance, while some radio stations may be in the same city (and perhaps the same building), sharing media content between two remote radio stations (e.g., in different cities) may be desired.
For example, the broadcasting company may own and/or operate four radio stations in Los Angeles (LA), three in Miami, five in Chicago, two in Toronto, and several more worldwide. If the broadcasting company's Los Angeles radio stations are housed in the same building, they may be considered part of the same media “family.” Radio stations in the same family can share resources, such as common information technology (IT) infrastructures and IT support staff. The radio stations in the same family can be connected to each other (and to the data they share) via a LAN, WAN or other network. Generally speaking, a radio station family may include, but is not limited to, stations within a same market, within a same city, or within a same physical space (e.g., building). Accordingly, one type of radio station family includes radio stations that are within a predefined geographic area or areas.
In one example, four downtown Los Angeles radio stations in one family may share databases, hardware and/or software systems for managing their radio content. Such radio content can include, for example, media content (e.g., audio files), programming schedules, advertisements, search catalogs, and push content (described below). The search catalogs can be associated with searching the family's local media content as well as media content of remote families owned and/or operated by the same broadcasting company. The push content can be associated with media content that one radio station family may transmit (e.g., by pre-defined business scenarios) to the broadcasting company's other radio families. Searching and sharing content can occur, for example, among radio families that have established a “friendship”, such as families owned and/or operated by the same broadcasting company that may desire to share media content (e.g., music and ads).
Consider a program director at a Los Angeles radio station who may be interested in finding and airing a song written or performed by a particular artist. Using a computer software user interface such as media content finder application 126, the program director may type in the name of the artist or group (e.g., “Chip Davis” or “Mannheim Steamroller”) and initiate the search. Initially, the system may search media content (e.g., database of songs) of the local Los Angeles radio station family to which the radio station belongs. The particular databases or repositories searched can include the media content of the radio stations within the family (e.g., those sharing common storage facilities in the same building). However, if the song cannot be located locally, the program director may widen the search to include radio families within the same radio station family friendship. Specifically, the search can be executed against the media content of Miami, Chicago, Toronto and other locations that are part of the same radio station family friendship. In particular, searching the databases or repositories of the other families in the friendship may occur automatically, or the widened search may be triggered explicitly by the program director.
If the requested media asset (e.g., an audio file or a specific musical piece) is located at a remote radio station family, the program director may elect to download the file. For example, downloading the file may include an initial step of verifying that the program director and/or the associated radio station family has the appropriate “rights” to download the file. Verification can include, for example, authorization of the requesting radio station family (e.g., is the family included in the friendship?) and specific musical piece-related access, such as rights based on copyright or royalty agreements. If rights to the particular media asset are verified, downloading can occur, such as via the Internet.
As shown in
In some implementations, the media content finder application 126 can be hosted on a radio station family's computer system, such as on the hardware within the common computer network shared by radio stations in the same building. In some implementations, the content is stored on a computer of a radio station within a family. In both of these cases, the “intelligence” used by the application 126 to share media content can reside entirely on the radio station family's computer system. Other families in the friendship can have similar software on their computer systems. In this way, a radio station family in the friendship can have local software that facilitates searching and sharing of media content with other families in the friendship. For example, the Los Angeles and Chicago radio families can search and share media content, such as a Chicago-stored song requested by the Los Angeles radio station family.
In other implementations, the software used for sharing media content among radio families can be hosted on a centralized system, such as at a server accessible via the Internet or at the broadcasting hub. A radio station family may, for example, simply connect to the Internet and register as a member of a family friendship. Other families within the same friendship can register in a similar way. Whenever media content are to be searched and/or shared among radio families in a friendship, the request and processing can be handled entirely by the centralized system. Having the media asset sharing software entirely hosted on the Internet can eliminate the need for computer infrastructure (e.g., hardware, IT support staff etc.) at the radio station family.
In further implementations, software for sharing media content among radio station families can be hosted partly on the family's computer network and partly in a central system. In this way, sharing media content can, for example, exploit efficiencies that may derive from family-to-family sharing without using a central system. Specifically, such a system may still use centralized processing for some sharing functions and family-to-family processing for other sharing functions, depending on, for example, predicted transfer speeds.
In some implementations, different types of family friendships may exist among a broadcast company's radio families. For example, the system may be configured to represent families having one or more classical music stations as sharing a “classical” friendship. Similarly, radio stations that normally air Spanish language music maybe members of a “Spanish” family friendship. Different friendships can be named explicitly for easy reference by station personnel, or they may be represented implicitly, for example, by the data that defines the families.
The storage software module 302 can receive and store information (e.g., metadata) about media content that is stored at the radio families. For example, when a radio station 204 in radio station family A 202a stores music or advertisements as media content 116, the family 202a can transmit corresponding metadata to the media content finder application 126. When the media content is a piece of music, the metadata may include the name of the song, the artist's name, the type of music (e.g., rock, classical, jazz), the song's length, the language in which the song is recorded, the radio station family that stores the media content, the date of recording, the date that the media is stored at the radio station, and or other notes. Other metadata may identify a composer, a producer, a category, a type number, an advertiser number, and other user-defined custom metadata. When the media content is an advertisement, the metadata may include the name of the advertiser, the length of the ad, the date the ad was created or received, and the scheduled broadcast times for the ad. Indexes based on the metadata for music and ads can be stored in the media content index file 312. Such an index file 312 can allow radio stations 204 to search for media content stored at other radio families. For example, terms in a search query can be used as potential matches against fields in the metadata upon which the index file 312 is based.
In some implementations, the storage software module 302 can store actual media content 116. For example, some radio families may not store all of their media content locally. Specifically, media content that is likely to be needed by several radio families in a radio friendship can be stored at a central location.
The search software module 304 can receive a search query and identify media content matching the query or that matches the query to a predefined degree. In particular, when the application 126 receives a search query from a radio station 204 for specific media content, the search software module 304 can identify the media family that stores the data. For example, a radio station 204 at the radio station family A 202a may submit a query for a specific piece of music. The query may be entered in an interface 320a (e.g., including one or more GUI screens) and transmitted to the application 126 via the network 102. The search software module 304 can use terms in the search query to access the media content index 312. Matching entries in the index 312 can be used to formulate a result set that is transmitted to the radio station 204 via the network 102. The result set can identify the locations (e.g., specific radio families) in which the media content 116 is stored. In some implementations, the result set can automatically include the media content requested in the query. In particular, users of application 126 may fee able to configure the search software module 304 to send a link to the media content, to automatically send the media content itself, depending on various pre-defined parameters, or to instruct the user to issue a specific request to download the media content. In some implementations, the user may request to download the media content immediately or at a predefined time in the future.
In some implementations, the search software module 304 can employ saved searches 314. User queries may be stored in the saved searches file 314 over time as queries are received from radio stations 204. A list of saved searches may be provided to a user (e,g., a program director) at a radio station in drop-down lists displayable in interfaces 320a or 320b, such as in GUI screens. In some implementations, the saved searches file 314 can be stored at the radio families. For example, radio station family B 202b can have local saved searches 314 for media content search queries it has issued over time.
In some implementations, saved searches 314 can include templates that a user (e.g., a program director) can quickly customize to build a query. Specifically, a template may allow the user to complete (and save) a query simply by filling in a few parameters, such as the name of a musician or song title. For example, a template for finding a specific new (e.g., less than a month old) song at any Spanish language radio station may be completed by the user simply by filling in the song title (e.g., without having to specify date ranges or languages).
In some implementations, the search software module 304 can be used to crawl media content 116 stored at radio stations 204 in one or more radio station families. Crawling the media content can be used to pre-populate the media content index file 312 if, for example, the media content finder application 126 is installed after media content 116 already exists at radio families. Crawling can also be used to verity the index file 312 or to reconstruct the index file 312 (e.g., for disaster recovery).
The authentication software module 306 can allow the application 126 to ensure that it is communicating with radio families within radio stations under its control. For example, when a radio station 204 in radio station family A 202a sends a query to the application 126, the authentication software module 306 can authenticate the request. For instance, the authentication software module 306 can compare information about the query's originator with information in a family friendships file 316. The family friendships file 316 can provide detailed information about the radio families and their associated radio stations, including radio station family identifiers that can be used for authentication. In some implementations, the family friendships file 316 can also include information that specifies protocols between the radio families, such as specific hours of operation or preferred times for sending or receiving media content.
The encryption software module 308 can provide security for exchanging media content among radio stations. For example, using shared encryption, media content 116 shared by radio station family A 202a can be encrypted before it is transmitted across the network 102. In some implementations, some of the functionality of the encryption software module 308 can reside at the radio station families. For example, radio station families 202a and 202b can each have an encryption software module 308 for encrypting media content they transmit, and for decrypting media content they receive.
The push software module 310 can automatically send specific media content to radio stations. For example, one of the radio station families may have a radio station 204 that has facilities (e.g., translators and recording studios) for creating Spanish language versions of popular songs. In particular, a broadcasting company with several radio station families may have a procedure in place for creating the Spanish versions of songs at a single radio station, then “pushing” the media content to other radio stations.
In one example sequence of pushing media content, a radio station 204 in radio station family A 202a creates the Spanish version of a particular song. After the song is stored locally in media content 116, the radio station family A 202a also transmits metadata corresponding to the Spanish song to the application 126. Upon receipt of the metadata, the storage software module 302 updates the media content index file 312. At the same time, the storage software module 302 accesses the family friendships file 316 and determines that the media content it just received can be automatically pushed to other Spanish language radio stations. The application 126 then invokes the push software module 310 to push the Spanish song to other radio families, such as to radio station family B 202b if it has one or more Spanish radio stations 204.
In some implementations, pushed media content can be reviewed by a radio station family before it is stored locally. For example, radio station family A 202a may use the interlace 320a to screen media content pushed to it from other radio families, such as from radio station family B 202b. Similarly radio station family B 202b may use the interface 320b to screen media content pushed to it from radio station family A 202a. In some implementations, pushed media content awaiting screening can be held by the application 126 (e.g., at the Internet site hosting the application 126). In other implementations, pushed media content awaiting screening can be stored at the radio families until it is screened.
In some implementations, a user in one family may use a different user interface (e.g., other than media content search screens) to initiate a transfer (e.g., push) of a specified media asset from one family to another. For example, a user at radio station family A 202a may identify a piece of music that the user believes radio station family B 202b may want. Using the interface, such as an interface that displays new media content processed for the day, the user can select the specific media content and push the specific media content to other families (e.g., radio station family B 202b).
In some implementations, when pushed media content (e.g., a pushed media asset) is received by one family from another family, the receiving system can automatically check pre-defined rules to determine if the incoming media asset must be held for screening. For example, the predefined rules may specify that screening is to occur for certain types of music (e.g., classical or rap) or for media content from specific radio families (e.g., radio family A 202a). If a particular media asset is held for screening, then the media asset can be quarantined until a user at the receiving family approves the media asset. Such approval can occur, for example, through the use of one or more user interface screens.
In some implementations, during the approval process (e.g., of quarantined media content), the approver may manually manipulate the metadata of an incoming media asset. For example, the program director at radio station family B 202b may receive pushed content from radio station family A 202A, such as a Spanish jazz song that is categorized as jazz. However, the user may wish to change the metadata, such as to further classify the song as a Spanish language song.
The media content information is stored (506) such that the media content information is accessible to at least some of the families of radio stations via a computer network. For example, if a song or ad is stored locally as media content 116 at radio families 202a or 202b, the metadata corresponding to the song or ad can be stored in the media content index 312. Indexes in the media content index 312 can make it possible for radio stations to search for other radio families' media content information, such as metadata (e.g., song title, artist, etc.) relating to songs by Mannheim Steamroller. As additional instances of media content information are stored over time, storage software module 302 can make the corresponding updates to the media content index 312 (steps 502-506).
To find media content stored in the families of radio stations, a query can be sent (508). For example, a user (e.g., a program director) at the radio station family B 202b may send a query for a song (e.g., a specific song by Mannheim Steamroller) previously stored by a radio station 204 at radio station family A 202a. The query can he entered by the user via interface 320b (e.g., 400—see
As shown in
Stored media content information is searched to identify the specific media content (512) that is the subject of the query. For example, the search software module 304 can use search terms from the search query it receives to access the media content index 312. Specifically, if the query contains a particular term (e.g., RECORDING_GROUP=“Mannheim Steamroller”), corresponding indexes in the index 312 can be searched.
Application 126 enables the radio station to access (514) the specific media content, provided that the specific media content is identified among the stored media content information. For example, when the search software module 304 identifies media content matching the user's query, the application 126 can provide the user with access to the corresponding media content. Specifically, the application 126 can send to the user a link to the Mannheim Steamroller song stored in media content 116 at radio station family A 202a. The link may appear as a hyperlink displayed in the user's interlace 320b. In some implementations, providing access to the media content may include sending the actual media content to the user. For example, the application 126 may obtain the media content wherever it is stored (e.g., in radio station family A 202a) and transmit a copy of the media content via the network 102 to the user at a radio station 204 in radio station family B 202b. In another implementation, application 126 may instruct a radio station in radio station family A 202a to send the media content directly (e.g., to push the media content) to a radio station in radio station family B 202b.
The radio station that requested the specific media content receives the media content (516). For example, the user who initiated the query for the specific media content (e.g., a song by Mannheim Steamroller) can initiate a download of the song. In some implementations, the download may be initiated by clicking on a hyperlink displayed with the Mannheim Steamroller song title in the user's interface 320b. The download may occur via the network 102. In some implementations, the download can occur directly between radio families. For example, a copy of the audio content for the Mannheim Steamroller song stored in media content 116 in radio station family A 202a can be transmitted (e.g., pushed) to the media content 116 in radio station family B 202b (e.g., in response to instructions from media content finder application 126). In other implementations, the media content may be routed though the Web site or clearinghouse that hosts the application 126. Alter specific media content is copied to another radio station family, the media content index 312 can be updated to indicate another location at which the media content is stored. In this way, a user searching for a specific song (or ad) can discover that the song (or ad) is already available locally in media content 116.
Computing device 600 includes a processor 602, memory 604, a storage device 606, a high-speed interface 608 connecting to memory 604 and high-speed expansion ports 610, and a low speed interface 612 connecting to low speed bus 614 and storage device 606. Each of the components 602, 604, 606, 608, 610, and 612, are interconnected using various busses, and may be mounted on a common motherboard or in other manners as appropriate. The processor 602 can process instructions for execution within the computing device 600, including instructions stored in the memory 604 or on the storage device 606 to display graphical information for a GUI on an external input/output device, such as display 616 coupled to high speed interface 608. In other implementations, multiple processors and/or multiple buses may be used, as appropriate, along with multiple memories and types of memory. Also, multiple computing devices 600 may be connected, with each device providing portions of the necessary operations (e.g., as a server bank, a group of blade servers, or a multi-processor system).
The memory 604 stores information within the computing device 600. In one implementation, the memory 604 is a machine-readable medium. In one implementation, the memory 604 is a volatile memory unit or units. In another implementation, the memory 604 is a non-volatile memory unit or units.
The storage device 606 is capable of providing mass storage for the computing device 600. In one implementation, the storage device 606 is a computer-readable medium. In various different implementations, the storage device 606 may be a floppy disk device, a hard disk device, an optical disk device, or a tape device, a flash memory or other similar solid state memory device, or an array of devices, including devices in a storage area network or other configurations. In one implementation, a computer program product is tangibly embodied in an information carrier. The computer program product contains instructions that, when executed, perform one or more methods, such as those described above. The information carrier is a computer- or machine-readable medium, such as the memory 604, the storage device 606, memory on processor 602, or a propagated signal.
The high speed controller 608 manages bandwidth-intensive operations for the computing device 600, while the low speed controller 612 manages lower bandwidth-intensive operations. Such allocation of duties is exemplary only. In one implementation, the high-speed controller 608 is coupled to memory 604, display 616 (e.g., through a graphics processor or accelerator), and to high-speed expansion ports 610, which may accept various expansion cards (not shown). In the implementation, low-speed controller 612 is coupled to storage device 606 and low-speed expansion port 614. The low-speed expansion port, which may include various communication ports (e.g., USB, Bluetooth, Ethernet, wireless Ethernet) may be coupled to one or more input/output devices, such as a keyboard, a pointing device, a scanner, or a networking device such as a switch or router, e.g., through a network adapter.
The computing device 600 may be implemented in a number of different forms, as shown in the figure. For example, it may be implemented as a standard server 620, or multiple times in a group of such servers. It may also be implemented as part of a rack server system 624. In addition, it may be implemented in a personal computer such as a laptop computer 622. Alternatively components from computing device 600 may be combined with other components in a mobile device (not shown), such as device 650. Each of such devices may contain one or more of computing device 600, 650, and an entire system may be made up of multiple computing devices 600, 650 communicating with each other.
Computing device 650 includes a processor 652, memory 664, an input/output device such as a display 654, a communication interface 666, and a transceiver 668, among other components. The device 650 may also be provided with a storage device, such as a microdrive or other device, to provide additional storage. Each of the components 650, 652, 664, 654, 666, and 668, are interconnected using various buses, and several of the components may be mounted on a common motherboard or in other manners as appropriate.
The processor 652 can process instructions for execution within the computing device 650, including instructions stored in the memory 664. The processor may also include separate analog and digital processors. The processor may provide, for example, for coordination of the other components of the device 650, such as control of user interlaces, applications run by device 650, and wireless communication by device 650.
Processor 652 may communicate with a user through control interface 658 and display interface 656 coupled to a display 654. The display 654 may be, for example, a TFT LCD display or an OLED display, or other appropriate display technology. The display interface 656 may comprise appropriate circuitry for driving the display 654 to present graphical and other information to a user. The control interface 658 may receive commands from a user and convert them for submission to the processor 652. In addition, an external interface 662 may be provide in communication with processor 652, so as to enable near area communication of device 650 with other devices. External interface 662 may provide, for example, for wired communication (e.g., via a docking procedure) or for wireless communication (e,g., via Bluetooth or other such technologies).
The memory 664 stores information within the computing device 650. In one implementation, the memory 664 is a computer-readable medium. In one implementation, the memory 664 is a volatile memory unit or units. In another implementation, the memory 664 is a non-volatile memory unit or units. Expansion memory 674 may also be provided and connected to device 650 through expansion interface 672, which may include, for example, a SIMM card interface. Such expansion memory 674 may provide extra storage space for device 650, or may also store applications or other information for device 650. Specifically expansion memory 674 may include instructions to carry out or supplement the processes described above, and may include secure information also. Thus, for example, expansion memory 674 may be provide as a security software module for device 650, and may be programmed with instructions that permit secure use of device 650. In addition, secure applications may be provided via the SIMM cards, along with additional information, such as placing identifying information on the SIMM card in a non-hackable manner.
The memory may include for example, flash memory and/or MRAM memory, as discussed below. In one implementation, a computer program product is tangibly embodied in an information carrier. The computer program product contains instructions that, when executed, perform one or more methods, such as those described above. The information carrier is a computer- or machine-readable medium, such as the memory 664, expansion memory 674, memory on processor 652, or a propagated signal.
Device 650 may communicate wirelessly through communication interface 666, which may include digital signal processing circuitry where necessary. Communication interface 666 may provide for communications under various modes or protocols, such as GSM voice calls, SMS, EMS, or MMS messaging, CDMA, TDMA, PDC, WCDMA, CDMA2000, or GPRS, among others. Such communication may occur, for example, through radio-frequency transceiver 668. In addition, short-range communication may occur, such as using a Bluetooth, WiFi, or other such transceiver (not shown). In addition, GPS receiver software module 670 may provide additional wireless data to device 650, which may be used as appropriate by applications running on device 650.
Device 650 may also communication audibly using audio codec 660, which may receive spoken information from a user and convert it to usable digital information. Audio codex 660 may likewise generate audible sound for a user, such as through a speaker, e.g., in a handset of device 650. Such sound may include sound from voice telephone calls, may include recorded sound (e.g., voice messages, music files, etc.) and may also include sound generated by applications operating on device 650.
The computing device 650 may be implemented in a number of different terms, as shown in the figure. For example, it may be implemented as a cellular telephone 680. It may also be implemented as part of a smartphone 682, personal digital assistant, or other similar mobile device.
Various implementations of the systems and techniques described here can be realized in digital electronic circuitry, integrated circuitry, specially designed ASICs (application specific integrated circuits), computer hardware, firmware, software, and/or combinations thereof. These various implementations can include implementation in one or more computer programs that are executable and/or interpretable on a programmable system including at least one programmable processor, which may be special or general purpose, coupled to receive data and instructions from, and to transmit data and instructions to, a storage system, at least one input device, and at least one output device.
These computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and can be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the terms “machine-readable medium” “computer-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine Instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor.
To provide for interaction with a user, the systems and techniques described here can be implemented on a computer having a display device (e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information, to the user and a keyboard and a pointing device (e.g., a mouse or a trackball) by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback); and input from the user can be received in any form, including acoustic, speech, or tactile input.
The systems and techniques described here can be implemented in a computing system that includes a back end component (e.g., as a data server), or that includes a middleware component (e.g., an application server), or that includes a front end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the systems and techniques described here), or any combination of such back end, middleware, or front end components. The components of the system can be interconnected by any form or medium of digital data communication (e.g., a communication network). Examples of communication networks include a local area network (“LAN”), a wide area network (“WAN”), and the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
Although a few implementations have been described in detail above, other modifications are possible. For example, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. In addition, other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other implementations are within the scope of the following claims.
The media content described herein may include, but is not limited to, any type of broadcast content, such as individual songs, playlists, talk radio programming, text, images, video, and advertising. Media content finder application 126 may also be used to search for media content within a radio station family. For example, one radio station in family 202a may use media content finder application 126 to search for media content in another radio station in family 202a.
Elements of the different implementations described herein may be combined in a manner not specifically described to produce new implementations.
Number | Name | Date | Kind |
---|---|---|---|
4517562 | Martinez | May 1985 | A |
4665514 | Ching et al. | May 1987 | A |
4723285 | Le Roy et al. | Feb 1988 | A |
4841357 | Gillies | Jun 1989 | A |
4845658 | Gifford | Jul 1989 | A |
4864620 | Bialick | Sep 1989 | A |
5096195 | Gimmon | Mar 1992 | A |
5129036 | Dean et al. | Jul 1992 | A |
5260778 | Kauffman et al. | Nov 1993 | A |
5303326 | Dean et al. | Apr 1994 | A |
5440351 | Ichino | Aug 1995 | A |
5515098 | Carles | May 1996 | A |
5557541 | Schulhof et al. | Sep 1996 | A |
5576755 | Davis et al. | Nov 1996 | A |
5697844 | Von Kohorn | Dec 1997 | A |
5715018 | Fasciano et al. | Feb 1998 | A |
5724521 | Dedrick | Mar 1998 | A |
5738583 | Comas et al. | Apr 1998 | A |
5948061 | Merriman et al. | Sep 1999 | A |
5999808 | LaDue | Dec 1999 | A |
6011973 | Valentine et al. | Jan 2000 | A |
6104815 | Alcorn et al. | Aug 2000 | A |
6167382 | Sparks et al. | Dec 2000 | A |
6198906 | Boetje et al. | Mar 2001 | B1 |
6212392 | Fitch et al. | Apr 2001 | B1 |
6256508 | Nakagawa et al. | Jul 2001 | B1 |
6260047 | Fox et al. | Jul 2001 | B1 |
6282548 | Burner et al. | Aug 2001 | B1 |
6286005 | Cannon | Sep 2001 | B1 |
6298218 | Lowe et al. | Oct 2001 | B1 |
6311214 | Rhoads | Oct 2001 | B1 |
6317784 | Mackintosh et al. | Nov 2001 | B1 |
6338043 | Miller | Jan 2002 | B1 |
6374177 | Lee et al. | Apr 2002 | B1 |
6388712 | Shinohara et al. | May 2002 | B1 |
6401075 | Mason et al. | Jun 2002 | B1 |
6411992 | Srinivasan et al. | Jun 2002 | B1 |
6416414 | Stadelmann | Jul 2002 | B1 |
6470180 | Kotzin et al. | Oct 2002 | B1 |
6502076 | Smith | Dec 2002 | B1 |
6508710 | Paravia et al. | Jan 2003 | B1 |
6509867 | McGibney | Jan 2003 | B1 |
6527638 | Walker et al. | Mar 2003 | B1 |
6527641 | Sinclair et al. | Mar 2003 | B1 |
6606745 | Maggio | Aug 2003 | B2 |
6628928 | Crosby et al. | Sep 2003 | B1 |
6628939 | Paulsen | Sep 2003 | B2 |
6650892 | Thiriet | Nov 2003 | B1 |
6674995 | Meyers et al. | Jan 2004 | B1 |
6678501 | Valeski | Jan 2004 | B1 |
6701355 | Brandt et al. | Mar 2004 | B1 |
6711474 | Treyz et al. | Mar 2004 | B1 |
6725022 | Clayton et al. | Apr 2004 | B1 |
6735435 | Newell et al. | May 2004 | B2 |
6747706 | Geddes et al. | Jun 2004 | B1 |
6767284 | Koza | Jul 2004 | B1 |
6778820 | Tendler | Aug 2004 | B2 |
6820055 | Saindon et al. | Nov 2004 | B2 |
6820277 | Eldering et al. | Nov 2004 | B1 |
6829475 | Lee et al. | Dec 2004 | B1 |
6850839 | McGibney | Feb 2005 | B1 |
6895238 | Newell et al. | May 2005 | B2 |
6915107 | Lusk | Jul 2005 | B1 |
6941324 | Plastina et al. | Sep 2005 | B2 |
6952559 | Bates et al. | Oct 2005 | B2 |
6957041 | Christensen et al. | Oct 2005 | B2 |
6961549 | Mori | Nov 2005 | B2 |
6963910 | Belknap et al. | Nov 2005 | B1 |
6975835 | Lake et al. | Dec 2005 | B1 |
6985882 | Del Sesto | Jan 2006 | B1 |
7036136 | Worthy | Apr 2006 | B1 |
7039930 | Goodman et al. | May 2006 | B1 |
7054592 | Tatsumi et al. | May 2006 | B2 |
7069582 | Philyaw et al. | Jun 2006 | B2 |
7085732 | Gould | Aug 2006 | B2 |
7158753 | Kagan et al. | Jan 2007 | B2 |
7167454 | Caldwell et al. | Jan 2007 | B2 |
7349663 | Joseph | Mar 2008 | B1 |
7801480 | Becker | Sep 2010 | B2 |
20010003099 | Von Kohorn | Jun 2001 | A1 |
20010018858 | Dwek | Sep 2001 | A1 |
20010037304 | Paiz | Nov 2001 | A1 |
20010048748 | Van Ryzin | Dec 2001 | A1 |
20010051559 | Cohen et al. | Dec 2001 | A1 |
20020023020 | Kenyon et al. | Feb 2002 | A1 |
20020038455 | Srinivasan et al. | Mar 2002 | A1 |
20020042923 | Asmussen et al. | Apr 2002 | A1 |
20020049037 | Christensen et al. | Apr 2002 | A1 |
20020056118 | Hunter et al. | May 2002 | A1 |
20020059646 | Kim | May 2002 | A1 |
20020069404 | Copeman et al. | Jun 2002 | A1 |
20020092019 | Marcus | Jul 2002 | A1 |
20020099600 | Merriman et al. | Jul 2002 | A1 |
20020122052 | Reich et al. | Sep 2002 | A1 |
20020133820 | Arai et al. | Sep 2002 | A1 |
20020168967 | Clapper | Nov 2002 | A1 |
20020178058 | Ritchie et al. | Nov 2002 | A1 |
20020194215 | Cantrell et al. | Dec 2002 | A1 |
20030003990 | Von Kohorn | Jan 2003 | A1 |
20030009452 | O'Rourke et al. | Jan 2003 | A1 |
20030023489 | McGuire et al. | Jan 2003 | A1 |
20030045273 | Pyhalammi et al. | Mar 2003 | A1 |
20030069032 | Jarvi et al. | Apr 2003 | A1 |
20030070167 | Holtz et al. | Apr 2003 | A1 |
20030093530 | Syed | May 2003 | A1 |
20030105809 | Yoshii et al. | Jun 2003 | A1 |
20030119528 | Pew et al. | Jun 2003 | A1 |
20030126616 | Dewa | Jul 2003 | A1 |
20030139190 | Steelberg et al. | Jul 2003 | A1 |
20030229559 | Panttaja et al. | Dec 2003 | A1 |
20040024633 | Whymark | Feb 2004 | A1 |
20040028388 | Kataoka et al. | Feb 2004 | A1 |
20040038723 | Schneier et al. | Feb 2004 | A1 |
20040064524 | Van Steenbergen et al. | Apr 2004 | A1 |
20040087326 | Dunko et al. | May 2004 | A1 |
20040093394 | Weber et al. | May 2004 | A1 |
20040103026 | White | May 2004 | A1 |
20040117826 | Karaoguz et al. | Jun 2004 | A1 |
20040127199 | Kagan et al. | Jul 2004 | A1 |
20040198217 | Lee et al. | Oct 2004 | A1 |
20040215515 | Perry | Oct 2004 | A1 |
20040236864 | Stevenson et al. | Nov 2004 | A1 |
20040244042 | Billmaier | Dec 2004 | A1 |
20050015800 | Holcomb | Jan 2005 | A1 |
20050020238 | Eastman et al. | Jan 2005 | A1 |
20050021396 | Pearch et al. | Jan 2005 | A1 |
20050039206 | Opdycke et al. | Feb 2005 | A1 |
20050043020 | Lipsanen et al. | Feb 2005 | A1 |
20050065806 | Harik | Mar 2005 | A1 |
20050065844 | Raj et al. | Mar 2005 | A1 |
20050090279 | Witkowski et al. | Apr 2005 | A9 |
20050105725 | Lee | May 2005 | A1 |
20050137958 | Huber et al. | Jun 2005 | A1 |
20050198317 | Byers | Sep 2005 | A1 |
20050227678 | Agrawal et al. | Oct 2005 | A1 |
20050239402 | Gioscia et al. | Oct 2005 | A1 |
20050267817 | Barton et al. | Dec 2005 | A1 |
20050278769 | Steelberg et al. | Dec 2005 | A1 |
20060019642 | Steelberg et al. | Jan 2006 | A1 |
20060133407 | Kuisma | Jun 2006 | A1 |
20060143236 | Wu | Jun 2006 | A1 |
20060146765 | Van de Sluis et al. | Jul 2006 | A1 |
20060176374 | Oklejas | Aug 2006 | A1 |
20060195863 | Whymark | Aug 2006 | A1 |
20060212901 | Steelberg et al. | Sep 2006 | A1 |
20060218401 | Jun | Sep 2006 | A1 |
20060248209 | Chiu et al. | Nov 2006 | A1 |
20060268667 | Jellison, Jr. et al. | Nov 2006 | A1 |
20060282533 | Steelberg et al. | Dec 2006 | A1 |
20060294571 | Moore et al. | Dec 2006 | A1 |
20070022459 | Gaebel et al. | Jan 2007 | A1 |
20070027958 | Haslam | Feb 2007 | A1 |
20070078712 | Ott et al. | Apr 2007 | A1 |
20070078714 | Ott et al. | Apr 2007 | A1 |
20070094042 | Ramer et al. | Apr 2007 | A1 |
20070118873 | Houh et al. | May 2007 | A1 |
20070130012 | Yruski et al. | Jun 2007 | A1 |
20070157261 | Steelberg et al. | Jul 2007 | A1 |
20070245020 | Ott | Oct 2007 | A1 |
20070250856 | Leavens et al. | Oct 2007 | A1 |
20070259318 | Harrison | Nov 2007 | A1 |
20080021710 | Ho | Jan 2008 | A1 |
20080046948 | Verosub | Feb 2008 | A1 |
20080077264 | Irvin et al. | Mar 2008 | A1 |
20080208378 | Booth et al. | Aug 2008 | A1 |
20080249982 | Lakowske | Oct 2008 | A1 |
20080253307 | Irvin | Oct 2008 | A1 |
20080254741 | Irvin | Oct 2008 | A1 |
20080255686 | Irvin et al. | Oct 2008 | A1 |
20080256080 | Irvin et al. | Oct 2008 | A1 |
20080256109 | Irvin et al. | Oct 2008 | A1 |
20090019374 | Logan et al. | Jan 2009 | A1 |
20100064338 | Steelberg et al. | Mar 2010 | A1 |
Number | Date | Country |
---|---|---|
1285079 | Feb 2001 | CN |
03-184486 | Aug 1991 | JP |
05-284162 | Oct 1993 | JP |
07-505028 | Jun 1995 | JP |
09-018430 | Jan 1997 | JP |
2000-244427 | Sep 2000 | JP |
2002-368704 | Dec 2002 | JP |
10-1997-0019597 | Apr 1997 | KR |
10-2001-0112410 | Dec 2001 | KR |
WO 9715999 | May 1997 | WO |
WO 9721183 | Jun 1997 | WO |
WO 9715999 | Jul 1997 | WO |
WO 9734384 | Sep 1997 | WO |
WO 9949663 | Sep 1999 | WO |
WO 0135667 | May 2001 | WO |
WO 0201869 | Jan 2002 | WO |
WO 0225467 | Mar 2002 | WO |
WO 0227425 | Apr 2002 | WO |
WO 0227425 | Apr 2002 | WO |
WO 2004017163 | Feb 2004 | WO |
WO 2004017163 | Nov 2004 | WO |
Number | Date | Country | |
---|---|---|---|
20080256080 A1 | Oct 2008 | US |