Embodiments of the present invention generally relate to delivering content to media playback systems and more particularly to selecting and delivering content into telephony applications.
Telephony applications can deliver a richer and more interesting experience to callers by integrating content from external sources. Examples of such applications include call center applications, unified messaging, voice mail, one-number applications, conference calling, on-hold, interactive voice response applications, and Voice Over IP systems. These applications may be hobbled by the lack of a system for selecting content appropriate to a given situation and delivering that content to the system for use in the application.
Accordingly, in one aspect of the present invention, there is provided a method for selecting and delivering content to a telephony application, including receiving a request from a telephony service for interactive content, initiating a method call to a content selection system, selecting a content item from a content cache with the content selection system, sending instructions for playing the selected content item to the telephony service, obtaining a content request for the selected content item based upon the instructions for playing the selected content item, and delivering the selected content item to the telephony service.
Additionally, using a system and method of the present invention, content may be requested by and delivered to a system that plays audio other than a telephony system. For example, content may be requested by and delivered into a radio station's audio broadcast, an Internet audio stream, or a podcast. The choice of content selected by the content selection system may take the playback source into account and select appropriate content accordingly. The content providers may also offer certain content to be played only through certain playback systems, or offer multiple versions of the content, each appropriate to one or more playback systems. Examples of such content include advertising, offers, stock information, sports scores, traffic information, weather, news, and the like.
Still other aspects, features, and advantages of the present invention are readily apparent from the following detailed description, by illustrating a number of exemplary embodiments and implementations, including the best mode contemplated for carrying out the present invention. The present invention is also capable of other and different embodiments, and its several details can be modified in various respects, all without departing from the spirit and scope of the present invention. Accordingly, the drawings and descriptions are to be regarded as illustrative in nature, and not as restrictive.
The embodiments of the present invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
Reference will now be made in detail to embodiments of the present invention. As used herein, the terms “a”, “an” and “the” may refer to one or more than one of an item. The terms “and” and “or” may be used in the conjunctive or disjunctive and will generally be understood to be equivalent to “and/or”.
There is a need for a method and system that addresses the above and other problems. The above and other problems are addressed by exemplary embodiments of the present invention, which provide for delivering interactive content to telephony systems and other media playback systems. Callers to the telephony systems may experience the content as an integral part of the system, but content providers (e.g., third-party content providers) may create the content separately from the telephony system itself. Additionally, content may be automatically selected on a per-call basis to provide a different and more appropriate interactive experience for each call. The content may be targeted to certain kinds of calls and/or callers, scheduled to run during a limited period of time, and limited to be served out a limited number of times.
For example, one of many possible advertisements might be selected for play on a certain call, based upon factors like its relevance to the caller, the time of day, the value of the advertisement, the number of times that advertisement is scheduled to be played in the next day, the number of calls expected to come in from a variety of telephony systems that are likely to be from callers with characteristics similar to the current caller, and so on.
Additionally, using a system and method of the present invention, content may be requested by and delivered to a system that plays audio other than a telephony system. For example, content may be requested by and delivered into a radio station's audio broadcast, an Internet audio stream, or a podcast. The choice of content selected by the content selection system may take the playback source into account and select appropriate content accordingly. The content providers may also offer certain content to be played only through certain playback systems, or offer multiple versions of the content, each appropriate to one or more playback systems. Examples of such content include advertising, offers, stock information, sports scores, traffic information, weather, news, and the like.
Contextual data related to the delivery of and interactions with served content may be made available to telephony system providers, content providers, and the owners of the system itself through Web-based interfaces and the like. This data may then be used by the system and method of the present invention to evaluate, select, and serve refined content to customize the delivered content, For example in a telephony environment, one of many possible advertisements might be selected for play on a certain call, based upon factors like its relevance to the caller, the time of day, the value of the advertisement, the number of times that advertisement is scheduled to be played in the next day, the number of calls expected to come in from a variety of telephony systems that are likely to be from callers with characteristics similar to the current caller, and so on.
Similarly in another audio delivery example, a radio station may have a scheduled opportunity in its audio broadcast to play content. Its automated scheduling and broadcast system then requests that content from the system, passing along contextual information. The content selection system then selects appropriate content for the radio broadcast, based upon that contextual information, information provided about each piece of content, and the fact that content is being selected for radio broadcast. It then passes back an appropriate item of content, which the radio station then plays on-air through its broadcast system.
Referring now to the drawings, wherein like reference numerals designate identical or corresponding parts throughout the several views, and more particularly to
As shown further in
Further, the content selection system may also include a monitoring module 140 that monitors the request from the telephony service for interactive content, monitors the selected content item from the content selection system, monitors the content request for the selected content item, monitors the delivery of the selected content item to the telephony service, and monitors actions taken by a user interacting with the telephony service. The content selection system may further include a revision module 150 that revises the call attributes, the content relevance, the content prioritization, or the content value based upon monitored activity.
The content server 104 may be in communication with the content selection system 106, which may be in communication with the content cache 108. Content cache 108 may be any type of high speed data storage mechanism, including independent storage devices, sections of computer memory, and the like. The storage mechanisms may further include static RAM, dynamic RAM, internal (L1) caches, external (L2) caches, disk sectors, and the like. Likewise, servers 102,104 may be any suitable servers, workstations, PCs, laptop computers, PDAs, Internet appliances, handheld devices, cellular telephones, wireless devices, other devices, and the like, capable of performing the processes of the exemplary embodiments.
The exemplary system 100 may also include an interactive advertising system 110 that receives a transferred telephone transmission from the telephony system and accesses additional content items.
For ease of understanding and not by way of limitation, the operation of the exemplary system 100 is now described with reference to
In operation 204, the content server 104 makes a method call to the content selection system 106. In operation 206, the content selection system 106 selects an item of content (i.e., content item) from the content cache 108. Examples of the content items include audio items as well as text items, graphical advertisements, video items and the like. In operation 208, the selected content item may be returned to the content server 104, which may send instructions for content playback and interactivity to the telephony service servers 102. The instructions may also contain references to content hosted on the content server 104. For example, the references to content may be additional audio content, video content, multimedia content, instant messaging text, ringtone content, and the like that may be added and delivered as an additional content items to supplement the initial audio content item. In operation 210, the telephony service servers 102 interpret the instructions and request the content from the content server 104 as needed. In operation 212, the selected content item is delivered to the telephony service servers 102.
Likewise, servers 302, 305 may be any suitable servers, workstations, PCs, laptop computers, PDAs, Internet appliances, handheld devices, cellular telephones, wireless devices, other devices, and the like, capable of performing the processes of the exemplary embodiments.
The exemplary system 300 may also include an interactive advertising system 310 that receives a transferred telephone transmission from the telephony system and accesses additional content items.
For ease of understanding and not by way of limitation, the operation of the system 300 is now described with reference to
In operation 2205, a VoiceXML instruction may direct the VoiceXML processor 304 to request a VoiceXML subdialog from the content server 306, and to pass targeting parameters to that subdialog in step 2206. In operation 2207, inside the subdialog, the parameters may be passed to the content server 306, which may select an appropriate item of content (e.g., an advertisement) from the content cache 308 in step 2208. Once the content server has selected an item of content, in step 2209 it may then generate the VoiceXML required to process that content. In operation 2210, the generated VoiceXML may be sent to the VoiceXML processor 304. In operation 2211, the VoiceXML processor 304 may read that generated VoiceXML and in step 2212 the VoiceXML processor may play the appropriate content (e.g., audio content) to the caller. In step 2213, the VoiceXML processor 304 handles any inputs (including lack of inputs or other user activities), which may be passed back to the VoiceXML server 305 so that subsequent VoiceXML pages may be generated and returned. When the content playback concludes, the subdialog may return, and the call may continue on the original telephony VoiceXML server 302.
For ease of understanding and not by way of limitation, another exemplary system in accordance with the present invention can request and deliver content to a telephony service system through Web services. The system may communicate with a Web services server via markup communicated over a protocol such as HTTP and the like. The Web services may request content from a content selection system and a content cache. The content selection system may respond with a content item that the Web services server then packages as a response to the telephony service system. The telephony service system may the play the returned content item.
There may be three types of content servers: primary master content servers 404, local master content servers 406, and slave content servers 408. For example, an entire In-Call Network Exchange (ICNX) system 400 may include one primary master content server 404, zero or more local master servers 406a, 406b, and zero or more slave content servers 408a, 408b, 418a, 418b, 418c, 418d.
The primary master content server 404 may handle a number of different tasks, including controlling the timing of when contents may be inserted and removed from the active selection of content based on start and end time of content, and day and time targeting of content. The primary master content server 404 also manages the state of the content as may be controlled by the play and pause functions of the management interface 402 and reflected in active selection of content. Further, the primary master content server 404 receives in-memory caches of current content impression counts from slave content servers 408, 418. The primary master content server 404 may also stop the delivery of an item of content, and transition it to the ended state, when in-memory caches of current content impression counts reach target impression counts. Additionally, the primary master content server 404 receives and collates reporting summaries from slave content servers 408, 418 and manages performance, billing, and payment reports.
A local master content server 406 may perform a number of tasks as well, including receiving in-memory caches of current content impression counts from slave content servers 408, 418 and reporting them up to their master content server 404, 406. A local master content server 406 also receives and collates reporting summaries from slave content servers 408, 418 and reports them up to its master content server 406, 404.
A slave content server 408, 418 may handle a variety of tasks, including receiving and responding to content requests from publishers, tracking in-memory cache of current content impression counts and reporting them up to its master, and summarizing content events and reporting them up to its master content server.
Each content server, regardless of whether it is a primary master content server 404, local master content server 406, or slave server 408, 418 may fill the role of any other content server. The role of a server may be controlled by the software configuration and the database configuration. Each content server may include the necessary software and data to fill any type of role. This provides redundancy for the primary master content server 404. If the primary master server 404 becomes unavailable, the system and method of the present invention may provide a procedure for promoting a local master content server 406 or a slave content server 408, 418 to become the primary content server 404.
In addition, each content server may perform the tasks of a slave content server 408, 418 at any time regardless of the current role they perform. Finally, each content server may have one master content server with which it may communicate, though the primary master content server 404 may not have a master above it.
There may be various primary types of data which may need to be distributed among content servers. These may include content-related data, reporting data, and impression data.
Content-related data may include data that defines items of content, content providers, and publishers. These data may be managed from the management interface 402, but some tasks may be performed by the primary master content server 404 on this data. This data may be mastered on the primary master database 508 and the distribution to local master content servers 406 and slave content servers 408 may be handled by the database itself via a replication system.
Reporting data may include all data associated with tracking content requests from publishers. The data may first be logged to the local reporting database 506 in a raw form. Processes in the slave content server 408 summarize this data to reduce reporting overhead and send this data to the slave content server's 408 master content server. Each intermediate local master content server may receive and collate the data, for example from multiple content servers, and send the collated data to its own master. Additionally, the primary master content server 404 may receive and collate this data in the primary master database 508 to be used by reporting, billing, and payment systems.
Impression data include the impression counts for items of content currently running or other data denoting numerical values or other analytics and metrics that may be used to determine the effectiveness of the items of content on the system. A purpose of this data may be to ensure that combined impression counts for content running on distributed content servers do not exceed the target impression count for the content that may be set by content providers. The target impression count may be set in the management interface 402 and may include an acceptable error range and criteria for counting impressions such as execution of code by a user's browser. This data may be stored in memory by slave content servers 408, or by master content servers performing slave operations, and transferred through local master content servers 406, to the primary master content server 404. After the primary master content server 404 receives this data, it may be written to the primary master database 508.
The example provided in
Returning to the example shown in
In operation 708, the user may add creative and configuration elements to the campaign. These may include any audio, video, or graphic files that may be needed to complete the content that makes up the campaign, any SMS/email/instant messaging text, ringtone content, such as a pre-ring content item, a ring replacement content item, or a busy signal replacement content item that may be delivered, phone numbers to which callers may be transferred and the like. At the end of each operation of this method 700, entered data may be stored in a database 716, such as the content cache 108 of
Once this information is provided, the user from the content provider 799 may be finished creating and submitting items of content into the system. In operation 710, the campaign may be reviewed by the system owners to verify that it is appropriate and well-formed. In operation 712, the system owners may configure pricing for the campaign, as well as other options, such as the prioritization of the campaign relative to other campaigns and reviewing the established campaign.
After review is complete, the information needed to determine which telephony service providers will play the content may be available, and these providers may, in operation 714, have the opportunity to review the campaign content as well. The telephony service providers may choose to accept or reject the content in the campaign. Any rejected content may not be served to that telephony service, while accepted content may be made available to be selected for play on that service. After a period of time, any un-reviewed content may be automatically accepted for play on the service, automatically rejected for play on the service, or otherwise acted upon by protocols determined by the providers.
For ease of understanding and not by way of limitation, the operation of the system 800 is now described with reference to
In operation 906, the selection process may utilize several reference tables in the reference database 810 to infer some of these attributes from others. For example, given a caller ID, the selection process may make a reasonable assumption as to whether the particular caller may fall into one or more income ranges. In operation 908, these attributes may be used in filtering to determine relevant content, That is, the selection process may be left with a smaller pool of content that may be more appropriate for the given caller. In operation 910, a notion of priority may be imposed. During the content-creation process, each item of content may be assigned a priority. Those priorities may be used at this point to filter the pool of possible content even further. In operation 912, a value of the content may be considered. Each item of content may include a value, which may include performance of the content item based on a calculable measure, and the dollar value of the cost of the content item.
In addition, the content selection process may also take into account prior telephone transmissions by the user, such as whether a particular piece of content has already been delivered to a caller during a call. If that is the case, that same content may not be delivered again. Further, the content selection process may also take into account a position for placement of the content item within a telephone transmission. Placement may be temporal such as content positioned to fit in a certain time frame or it may be physical such as a graphic ad placement on a user's cell phone screen. At this point, the selection process may have determined a final list of potential content that may be most relevant to serve for a particular caller. A single item of content may be chosen, for example, randomly from this list or according to some other pattern of delivery. In operation 914, the content selection system 806 may then deliver the selected content to the content server 804 that requested the content.
The content selection process may also monitor, record, examine, and characterize various actions performed by the telephony service, the user, or by the content selection system to revise one or more of the call attributes, the content relevance, the content prioritization, and the content value based on the scrutinized activity, The various actions may include monitoring the request from the telephony service for interactive content, recording the selected content item from the content selection system, examining the content request from the selected content item, characterizing the delivery of the selected content item to the telephony service, and evaluating actions taken by a user interacting with the telephony service.
Further, the performance of a selected content item may be reviewed. Performance may be characterized by one or more of revenue derived from the selected content item and a count of the number of times that the selected content item is delivered to the telephony service. The count of the number of times that the selected content item is delivered may be measured in a number of ways, including measuring the number of times a user selects a delivered hot link, such as an ad, on their cell phone, or by measuring the number of lines of text a user scrolls through on their cell phone. Of course other metrics and performance criteria may also be used to characterize performance of a selected content item.
The content selection process may further transfer a telephone transmission to an interactive advertising system to access additional items.
The above-described exemplary embodiments may be appropriate for a number of different contexts. Not by way of limitation, these contexts may include a calling card system, an on-hold system, and a Voice Over IP system. In the calling card context, a user may be presented with content while using a calling card. In the on-hold context, a user may be presented with content while on hold. In the Voice Over IP context, a user may be presented with content during the process of making a call.
For ease of understanding and to provide additional examples, and not by way of limitation, the above contexts are now described with reference to the exemplary system 100 of
The above-described devices and subsystems of the exemplary embodiments can include, for example, any suitable servers, workstations, PCs, laptop computers, PDAs, Internet appliances, handheld devices, cellular telephones, wireless devices, other devices, and the like, capable of performing the processes of the exemplary embodiments. The devices and subsystems of the exemplary embodiments can communicate with each other using any suitable protocol and can be implemented using one or more programmed computer systems or devices.
One or more interface mechanisms can be used with the exemplary embodiments, including, for example, Internet access, telecommunications in any suitable form such as voice, modem, and the like, wireless communications media, and the like. For example, employed communications networks or links can include one or more wireless communications networks, cellular communications networks, G3 communications networks, Public Switched Telephone Network (PSTNs), Packet Data Networks (PDNs), the Internet, intranets, a combination thereof, and the like.
It is to be understood that the devices and subsystems of the exemplary embodiments are for illustrative purposes, as many variations of the specific hardware used to implement the exemplary embodiments are possible, as will be appreciated by those skilled in the relevant arts. For example, the functionality of one or more of the devices and subsystems of the exemplary embodiments can be implemented via one or more programmed computer systems or devices.
To implement such variations as well as other modifications, a single computer system can be programmed to perform the special purpose functions of one or more of the devices and subsystems of the exemplary embodiments. On the other hand, two or more programmed computer systems or devices can be substituted for any one of the devices and subsystems of the exemplary embodiments. Accordingly, principles and advantages of distributed processing, such as redundancy, replication, and the like, also can be implemented as desired, to increase the robustness and performance of the devices and subsystems of the exemplary embodiments.
The devices and subsystems of the exemplary embodiments can store information relating to various processes described herein. This information can be stored in one or more memories, such as a hard disk, optical disk, magneto-optical disk, RAM, and the like, of the devices and subsystems of the exemplary embodiments. One or more databases of the devices and subsystems of the exemplary embodiments can store the information used to implement the exemplary embodiments of the present inventions. The databases can be organized using data structures such as records, tables, arrays, fields, graphs, trees, lists, and the like, included in one or more memories or storage devices. The processes described with respect to the exemplary embodiments can include appropriate data structures for storing data collected and/or generated by the processes of the devices and subsystems of the exemplary embodiments in one or more databases thereof.
All or a portion of the devices and subsystems of the exemplary embodiments can be conveniently implemented using one or more general purpose computer systems, microprocessors, digital signal processors, micro-controllers, and the like, programmed according to the teachings of the exemplary embodiments of the present inventions, as will be appreciated by those skilled in the computer and software arts. Appropriate software can be readily prepared by programmers of ordinary skill based on the teachings of the exemplary embodiments, as will be appreciated by those skilled in the software art. Further, the devices and subsystems of the exemplary embodiments can be implemented on the World Wide Web. In addition, the devices and subsystems of the exemplary embodiments can be implemented by the preparation of application-specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as will be appreciated by those skilled in the electrical arts. Thus, the exemplary embodiments are not limited to any specific combination of hardware circuitry and/or software.
Stored on any one or on a combination of computer readable media, the exemplary embodiments of the present inventions can include software and instructions for controlling the devices and subsystems of the exemplary embodiments, for driving the devices and subsystems of the exemplary embodiments, for enabling the devices and subsystems of the exemplary embodiments to interact with a human user, and the like. Such software can include, but is not limited to, device drivers, firmware, operating systems, development tools, applications software, and the like. Such computer readable media further can include the computer program product of an embodiment of the present inventions with instructions recorded thereon for performing all or a portion (if processing is distributed) of the processing performed in implementing the inventions. Computer code devices of the exemplary embodiments of the present inventions can include any suitable interpretable or executable code mechanism, including but not limited to scripts, interpretable programs, dynamic link libraries (DLLs), Java classes and applets, complete executable programs, Common Object Request Broker Architecture (CORBA) objects, and the like. Moreover, parts of the processing of the exemplary embodiments of the present inventions can be distributed for better performance, reliability, cost, and the like.
As stated above, the devices and subsystems of the exemplary embodiments can include computer readable medium or memories for holding instructions programmed according to the teachings of the present inventions and for holding data structures, tables, records, and/or other data described herein. Computer readable medium can include any suitable medium that provides instructions to a processor for execution. Such a medium can take many forms, including but not limited to, non-volatile media, volatile media, transmission media, and the like. Non-volatile media can include, for example, optical or magnetic disks, magneto-optical disks, and the like. Volatile media can include dynamic memories, and the like. Transmission media can include coaxial cables, copper wire, fiber optics, and the like. Transmission media also can take the form of acoustic, optical, electromagnetic waves, and the like, such as those generated during radio frequency (RF) communications, infrared (IR) data communications, and the like. Common forms of computer-readable media can include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other suitable magnetic medium, a CD-ROM, CDRW, DVD, any other suitable optical medium, punch cards, paper tape, optical mark sheets, any other suitable physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other suitable memory chip or cartridge, a carrier wave or any other suitable medium from which a computer can read.
Thus, the exemplary embodiments include various novel features, for example, including a system for selecting and delivering content to a telephony application, to be delivered to the caller at some point during a call, where that content may include instructions for handling interactions with the caller, also to be interpreted and handled by the telephony application. Alternatively, the phone call may be transferred to the telephony application itself, which may take the selected content and play it for the caller, as well as handle any interactivity associated with the content. The telephony application can be a separate system on separate hardware with a separate owner from that of the claimed system. The telephony application may provide information to the system to allow for more targeted content selection. The telephony application may provide information about interactions of the caller with the content, for, among other uses, the purpose of tracking such interactions. There may be multiple telephony applications all requesting data from a single system. The content may be added to the system by a party other than the system owner. That content may be scheduled to only be available for a certain period of time, and may be indicated to require a certain number of deliveries to telephony applications over a period of time. That content may be targeted to only be delivered in certain circumstances, such as according to characteristics of the caller, the time of day or day of week, characteristics of the telephony application, prior user interaction, and so on. That content may be selected for delivery to a telephony provider based upon such targeting, as well as upon other prioritization considerations, such as stated requirements for the number of times a piece of content is delivered over a period of time, or a requirement that a set of content with shared characteristics may be delivered a certain number of times over a period of time. That content may include additional media and interactions outside the call itself such as SMS or email delivery, or transfer of the call to a different telephony system or phone number, where a content provider may be charged for the delivery of said content, and where the system may track money owed and create invoices, where a telephony provider may be paid for the playback of said content, and where the system may track money owed and create invoices, where content delivery is tracked by the system, and data is collected on its delivery, such as the number of times a piece of content has been delivered, or the number of times a user has selected an interaction with the content, where that data may be made accessible to the content provider, such as through a Web interface, where a telephony provider may review content that may be delivered to its system before that content can be played on that system, and reject content it deems inappropriate to its system, such as through a Web interface, and the like.
While the present inventions have been described in connection with a number of exemplary embodiments, and implementations, the present inventions are not so limited, but rather cover various modifications, and equivalent arrangements, which fall within the purview of prospective claims.
The present application claims the benefit of priority of U.S. Provisional Patent Application Ser. No. 60/929,880 entitled “SYSTEM AND METHOD FOR SELECTING AND DELIVERING CONTENT INTO A TELEPHONY APPLICATION” filed Jul. 16, 2007. The provisional application is incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
60929880 | Jul 2007 | US |