The disclosure relates to data distribution. More particularly, the methods and systems described herein relate to identification of opportunities to increase a level of distribution of data.
Conventional methods for identifying opportunities to increase a level of distribution of data typically focus on analyzing an attribute of the data itself. However, such typical methods may be limited in the ability to identify additional opportunities for increasing a level of distribution of the data since such conventional systems do not typically provide functionality for analyzing other potentially relevant types of data.
The foregoing and other objects, aspects, features, and advantages of the disclosure will become more apparent and better understood by referring to the following description taken in conjunction with the accompanying drawings, in which:
In some embodiments, the methods and systems described herein provide functionality for identifying distribution opportunities based on adjacent keywords. Before describing these methods and systems in detail, however, a description is provided of a network in which such methods and systems may be implemented.
Referring now to
Although
The network 104 may be any type and/or form of network and may include any of the following: a point to point network, a broadcast network, a wide area network, a local area network, a telecommunications network, a data communication network, a computer network, an ATM (Asynchronous Transfer Mode) network, a SONET (Synchronous Optical Network) network, an SDH (Synchronous Digital Hierarchy) network, a wireless network and a wireline network. In some embodiments, the network 104 may comprise a wireless link, such as an infrared channel or satellite band. The topology of the network 104 may be a bus, star, or ring network topology. The network 104 may be of any such network topology as known to those ordinarily skilled in the art capable of supporting the operations described herein. The network may comprise mobile telephone networks utilizing any protocol or protocols used to communicate among mobile devices, including AMPS, TDMA, CDMA, GSM, GPRS, or UMTS. In some embodiments, different types of data may be transmitted via different protocols. In other embodiments, the same types of data may be transmitted via different protocols.
A client 102 and a remote machine 106 (referred to generally as computing devices 100) can be any workstation, desktop computer, laptop or notebook computer, server, portable computer, mobile telephone or other portable telecommunication device, media playing device, a gaming system, mobile computing device, or any other type and/or form of computing, telecommunications or media device that is capable of communicating on any type and form of network and that has sufficient processor power and memory capacity to perform the operations described herein. A client 102 may execute, operate or otherwise provide an application, which can be any type and/or form of software, program, or executable instructions, including, without limitation, any type and/or form of web browser, web-based client, client-server application, an ActiveX control, or a Java applet, or any other type and/or form of executable instructions capable of executing on client 102.
In one embodiment, a computing device 106 provides functionality of a web server. In some embodiments, a web server 106 comprises an open-source web server such as the APACHE servers maintained by the Apache Software Foundation of Delaware. In other embodiments, the web server executes proprietary software such as the Internet Information Services products provided by Microsoft Corporation of Redmond, Wash., the Oracle iPlanet web server products provided by Oracle Corporation of Redwood Shores, Calif., or the BEA WEBLOGIC products provided by BEA Systems of Santa Clara, Calif. In further embodiments, a computing device 106 executes self-replication software. In one of these embodiments, execution of the self-replication software allows a computing device 106a to direct a second computing device 106b to provide a copy of data stored by the computing device 106. For example, the computing device 106a may provide access to a web site and, upon execution of the self-replication software, direct the second computing device 106b to provide access to a copy of the web site.
In some embodiments, the system may include multiple, logically-grouped remote machines 106. In one of these embodiments, the logical group of remote machines may be referred to as a server farm 38. In another of these embodiments, the server farm 38 may be administered as a single entity.
The central processing unit 121 is any logic circuitry that responds to and processes instructions fetched from the main memory unit 122. In many embodiments, the central processing unit 121 is provided by a microprocessor unit such as: those manufactured by Intel Corporation of Mountain View, Calif.; those manufactured by Motorola Corporation of Schaumburg, Ill.; those manufactured by Transmeta Corporation of Santa Clara, Calif.; those manufactured by International Business Machines of White Plains, N.Y.; or those manufactured by Advanced Micro Devices of Sunnyvale, Calif. The computing device 100 may be based on any of these processors, or any other processor capable of operating as described herein.
Main memory unit 122 may be one or more memory chips capable of storing data and allowing any storage location to be directly accessed by the microprocessor 121. The main memory 122 may be based on any available memory chips capable of operating as described herein. In the embodiment shown in
In the embodiment shown in
A wide variety of I/O devices 130a-130n may be present in the computing device 100. Input devices include keyboards, mice, trackpads, trackballs, microphones, scanners, cameras, and drawing tablets. Output devices include video displays, speakers, inkjet printers, laser printers, and dye-sublimation printers. An I/O controller 123 as shown in
Referring still to
Furthermore, the computing device 100 may include a network interface 118 to interface to the network 104 through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (e.g., 802.11, T1, T3, 56 kb, X.25, SNA, DECNET), broadband connections (e.g., ISDN, Frame Relay, ATM, Gigabit Ethernet, Ethernet-over-SONET), wireless connections, or some combination of any or all of the above. Connections can be established using a variety of communication protocols (e.g., TCP/IP, IPX, SPX, NetBIOS, Ethernet, ARCNET, SONET, SDH, Fiber Distributed Data Interface (FDDI), RS232, IEEE 802.11, IEEE 802.11a, IEEE 802.11b, IEEE 802.11g, IEEE 802.11n, CDMA, GSM, WiMax, and direct asynchronous connections). In one embodiment, the computing device 100 communicates with other computing devices 100′ via any type and/or form of gateway or tunneling protocol such as Secure Socket Layer (SSL) or Transport Layer Security (TLS). The network interface 118 may comprise a built-in network adapter, network interface card, PCMCIA network card, card bus network adapter, wireless network adapter, USB network adapter, modem or any other device suitable for interfacing the computing device 100 to any type of network capable of communication and performing the operations described herein.
In some embodiments, the computing device 100 may comprise or be connected to multiple display devices 124a-124n, each of which may be of the same or different type and/or form. As such, any of the I/O devices 130a-130n and/or the I/O controller 123 may comprise any type and/or form of suitable hardware, software, or combination of hardware and software to support, enable or provide for the connection and use of multiple display devices 124a-124n by the computing device 100. One ordinarily skilled in the art will recognize and appreciate the various ways and embodiments that a computing device 100 may be configured to have multiple display devices 124a-124n.
In further embodiments, an I/O device 130 may be a bridge between the system bus 150 and an external communication bus such as a USB bus, an Apple Desktop Bus, an RS-232 serial connection, a SCSI bus, a FireWire bus, a FireWire 800 bus, an Ethernet bus, an AppleTalk bus, a Gigabit Ethernet bus, an Asynchronous Transfer Mode bus, a HIPPI bus, a Super HIPPI bus, a SerialPlus bus, a SCI/LAMP bus, a FibreChannel bus, or a Serial Attached small computer system interface bus.
A computing device 100 of the sort depicted in
The computing device 100 can be any workstation, desktop computer, laptop or notebook computer, server, portable computer, mobile telephone or other portable telecommunication device, media playing device, a gaming system, mobile computing device, or any other type and/or form of computing, telecommunications or media device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein. In some embodiments, the computing device 100 may have different processors, operating systems, and input devices consistent with the device. In other embodiments the computing device 100 is a mobile device such as a JAVA-enabled cellular telephone or personal digital assistant (PDA). The computing device 100 may be a mobile device such as those manufactured, by way of example and without limitation, by Motorola Corp. of Schaumburg, Ill.; Kyocera of Kyoto, Japan; Samsung Electronics Co., Ltd. of Seoul, Korea; Nokia of Finland; Hewlett-Packard Development Company, L.P. and/or Palm, Inc. of Sunnyvale, Calif.; Sony Ericsson Mobile Communications AB of Lund, Sweden; or Research In Motion Limited of Waterloo, Ontario, Canada. In yet other embodiments, the computing device 100 is a smart phone, Pocket PC, Pocket PC Phone, or other portable mobile device supporting Microsoft Windows Mobile Software.
In some embodiments, the computing device 100 is a digital audio player. In one of these embodiments, the computing device 100 is a digital audio player such as the Apple IPOD, IPOD Touch, IPOD NANO, and IPOD SHUFFLE lines of devices, manufactured by Apple Inc. of Cupertino, Calif. In another of these embodiments, the digital audio player may function as both a portable media player and as a mass storage device. In other embodiments, the computing device 100 is a digital audio player such as those manufactured by, for example, and without limitation, Samsung Electronics America of Ridgefield Park, N.J., Motorola Inc. of Schaumburg, Ill., or Creative Technologies Ltd. of Singapore. In yet other embodiments, the computing device 100 is a portable media player or digital audio player supporting file formats including, but not limited to, MP3, WAV, M4A/AAC, WMA Protected AAC, AEFF, Audible audiobook, Apple Lossless audio file formats, and .mov, .m4v, and .mp4 MPEG-4 (H.264/MPEG-4 AVC) video file formats.
In some embodiments, the computing device 100 comprises a combination of devices such as a mobile phone combined with a digital audio player or portable media player. In one of these embodiments, the computing device 100 is a device in the Motorola line of combination digital audio players and mobile phones. In another of these embodiments, the computing device 100 is a device in the iPhone smartphone line of devices manufactured by Apple Inc. of Cupertino, Calif. In still another of these embodiments, the computing device 100 is a device executing the Android open source mobile phone platform distributed by the Open Handset Alliance; for example, the device 100 may be a device such as those provided by Samsung Electronics of Seoul, Korea or HTC Headquarters of Taiwan, R.O.C. In other embodiments, the computing device 100 is a tablet device such as, for example and without limitation, the iPad line of devices manufactured by Apple Inc.; the PlayBook manufactured by Research in Motion; the Cruz line of devices manufactured by Velocity Micro, Inc. of Richmond, Va.; the Folio and Thrive line of devices manufactured by Toshiba America Information Systems, Inc. of Irvine, Calif.; the Galaxy line of devices manufactured by Samsung; the HP Slate line of devices manufactured by Hewlett-Packard; and the Streak line of devices manufactured by Dell, Inc. of Round Rock, Tex.
In some embodiments, the methods and systems described herein provide functionality for identifying distribution opportunities. In one of these embodiments, individuals distributing data may use the methods and systems described herein to identify additional channels for their data in order to increase a level of distribution of the data. In another of these embodiments, and by way of example, a user may be distributing video for branding purposes (e.g., to increase a level of awareness about themselves, a company, an issue, or other topic) and may identify a first distribution channel for the video; by implementing the methods and systems described herein, however, the user may identify additional channels (e.g., channels not immediately obvious based on an analysis of the video) through which he can distribute the video for increased levels of distribution.
Referring now to
In one embodiment, the data aggregator 202 executes on the machine 106. In another embodiment, the data aggregator 202 is provided as a software application. In still another embodiment, the data aggregator 202 is provided as a hardware application. In another embodiment, the data aggregator 202 includes a receiver. The receiver may receive data from the client 102 such as, without limitation, the identification of the video and the identification of the distribution channel of the video, or from other computing devices such as, without limitation, a video sharing network computing device 210, a social network computing device 212, or a search engine computing device 214. In still another embodiment, the data aggregator 202 includes a transmitter for sending requests for data stored on other computing devices. In some embodiments, the data aggregator 202 includes functionality for issuing requests in accordance with application programming interfaces (API). For example, the data aggregator 202 may include functionality for requesting data from a social network computing device 212, the request formatted according to an API made available by the social network computing device 212.
In one embodiment, the profile generator 204 executes on the machine 106. In another embodiment, the profile generator 204 is provided as a software application. In still another embodiment, the profile generator 204 is provided as a hardware application. In another embodiment, the profile generator 204 includes a receiver for receiving data from other components executing on the machine 106. In still another embodiment, the profile generator 204 includes functionality for storing data in and retrieving data from local or remote databases (not shown). In some embodiments, the profile generator 204 includes functionality for retrieving data from the data aggregator 202 and generating a profile of a type of data based upon the retrieved data.
In one embodiment, the recommendation engine 206 executes on the machine 106. In another embodiment, the recommendation engine 206 is provided as a software application. In still another embodiment, the recommendation engine 206 is provided as a hardware application. In another embodiment, the recommendation engine 206 includes functionality for retrieving a profile (e.g., from the profile generator 204 or from a database storing generated profiles). In still another embodiment, the recommendation engine 206 includes functionality for analyzing retrieved data. In yet another embodiment, the recommendation engine 206 includes functionality for identifying distribution channels and determining whether to recommend the use of the identified distribution channels for increasing a level of distribution of a particular piece of data. For example, and without limitation, the recommendation engine 206 may include a profile analyzer, a channel identifier, a channel analyzer, and a recommendation generator (depicted in shadow in
In one embodiment, the video sharing network computing device 210 is a computing device 106 associated with a video sharing network (e.g., a server owned or maintained or otherwise associated with the video sharing network). Video sharing networks may include, for example and without limitation, networks made available by YouTube, LLC of San Bruno, Calif., Vimeo, LLC of New York, N.Y., and Dailymotion, Societe Anonyme of Paris, France.
In one embodiment, the social networking computing device 212 is a computing device 106 associated with a social network (e.g., a server owned or maintained or otherwise associated with the social network). Social networks may include, for example and without limitation, networks made available by Facebook, Inc. of Menlo, Park, Calif.; Twitter, Inc. of San Francisco, Calif.; LinkedIn Corporation of Mountain View, Calif.; and Pinterest, Inc. of Palo Alto, Calif. In some embodiments, although video sharing networks and social networks may have common functionality (e.g., functionality for commenting on data shared by users) and while users of social networks may share data such as video, the predominant use of a social network need not be video sharing.
In one embodiment, the search engine computing device 214 is a computing device 106 associated with a search engine company (e.g., a server owned or maintained or otherwise associated with a company providing a public interface to a search engine). Search engines may include, for example and without limitation, the GOOGLE search engine made available by Google, Inc. of Mountain View, Calif.; the BING search engine made available by Microsoft Corporation of Redmond, Wash.; the YAHOO! search engine made available by Yahoo! Inc. of Sunnyvale, Calif.; and the METACRAWLER search engine made available by InfoSpace, Inc. of Bellevue, Wash. In some embodiments, although video sharing networks and search engines may have some common functionality (e.g., functionality for searching for a video shared by a user), the predominant use of a conventional search engine is not typically to share data but rather to find data. In other embodiments, a video sharing network may provide access to search engine functionality. In further embodiments, a social network may provide access to search engine functionality.
In one embodiment, the client 102 is associated with a user seeking additional distribution channels for data. For example, the user may have created a video and identified a first distribution channel for the video. However, by interacting with the components executing on machine 106 to implement the methods and systems described herein, the user may identify additional distribution channels in which to distribute the video. Although depicted in
Referring now to
Referring now to
In one embodiment, instead of receiving an identification of a video and an identification of a distribution channel of the video, the machine 106 receives metadata for use in identifying distribution opportunities. In such an embodiment, instead of using the identification of the video and the identification of the distribution channel of the video for retrieving metadata and performing the functionality described below, the machine 106 uses the received metadata to retrieve additional metadata and perform the functionality described below.
The first computing device retrieves, from a video sharing network, metadata associated with the video (304). In some embodiments, the data aggregator 202 retrieves the metadata. In one embodiment, the machine 106 analyzes the identified video to identify the metadata to retrieve. For example, in an embodiment in which the machine 106 retrieves a copy of the video, a video analysis component (not shown) analyzes the video file to identify metadata—such as, without limitation, keywords provided with the video. In another embodiment, the machine 106 receives the metadata from a user instead of, or in addition to, the identification of the video and the identification of the distribution channel. However, in other embodiments, the machine 106 does not receive the metadata from the user and instead transmits requests to other computing devices for the metadata. For example, the machine 106 may use an API to retrieve the metadata from the video sharing network computing device 210—for instance, using an API to retrieve comments viewers of the video wrote and uploaded to the distribution channel and analyzing the comments to identify keywords, sentiment, popularity, and other metadata.
In some embodiments, the retrieved metadata includes data about a distribution channel that displayed the video. In one of these embodiments, the retrieved metadata identifies a source from which traffic to the distribution channel originated. For example, the retrieved metadata may indicate whether traffic to the distribution channel originated from advertising displayed on another distribution channel. As another example, the retrieved metadata may indicate whether traffic to the distribution channel originated from a viewer clicking on a URL included in a mention of the video shared on a social network. As a further example, the retrieved metadata may identify a type of device from which a viewer of the video accessed the distribution channel (e.g., from a mobile computing device, from a desktop computing device, or from a tablet computing device). In one embodiment, the machine 106 analyzes the retrieved metadata and identifies, based on the analysis, a source from which traffic to the distribution channel originated; the machine 106 may then correlate the identified source with a characteristic of the distribution channel based upon the identified source and include an identification of the characteristic in the distribution channel profile 230. In such an embodiment, the channel-related metadata may provide additional information about the nature of a channel and its relevance to the video. For example, demographic data may be inferred from the channel-related metadata and used in providing a recommendation related to the video. As another example, the machine 106 may correlate one or more relevant characteristics, such as the popularity of a channel on a social media channel, with one or more types of traffic sources. The machine 106 may determine how to perform the correlation based on one or more requirements specified by a user of the system. For instance, a first advertiser might want to target young viewers between 13 and 25 and prefer video channels that have a large footprint on social media while a second advertiser might want to target men 35-55 who actively search for information about a certain type of product; the machine 106 may determine which characteristics are relevant and how to correlate relevant characteristics with a traffic source based on the requirements of the specific advertiser for which the machine 106 makes a recommendation.
Referring now to
Referring again to
In another embodiment, the first computing device retrieves, from a social network computing device 212, social network data associated with the metadata. For example, the machine 106 may retrieve, from a social network computing device 212, data indicating that a user of the social network shared the video on the social network and commented on it (e.g., indicated that he liked the video, didn't like the video, or had a comment about the video). In some embodiments, the data aggregator 202 retrieves the data. In other embodiments, the data aggregator 202 retrieves and aggregates social network data associated with the distribution channel. In one of these embodiments, the data aggregator 202 retrieves and aggregates data associated with both the metadata for the video and metadata for the distribution channel. In other embodiments, the data aggregator 202 retrieves and aggregates social network data associated with the video.
In some embodiments, the data aggregator 202 performs an initial analysis of data retrieved from the second computing device in the second network, the data having at least one characteristic in common with the metadata. In one of these embodiments, by way of example, the data aggregator 202 performs an analysis to determine whether to retrieve additional data. For example, the data aggregator may have retrieved data having at least one characteristic in common with the metadata (such as a similar keyword embedded in a comment, or a synonym of the metadata used as a keyword) and analyze the retrieved data to determine whether to retrieve additional data (such as, continuing with the example above, data associated with the synonym of the metadata). Based upon the initial analysis, the data aggregator 202 may determine to retrieve additional data; for instance, retrieving an identification of a second video associated with a keyword that is a synonym for the metadata. In some embodiments, and as will be discussed in additional detail below, the profile generator 204 and the recommendation engine 206 may also perform additional analyses of the data.
The first computing device generates a profile of the video based on the retrieved data and the metadata (308). In one embodiment, the profile generator 204 executing on the machine 106 generates the profile. In another embodiment, the profile generator 204 retrieves data and metadata from the data aggregator 204. In still another embodiment, the profile generator 204 retrieves data and metadata from a database storing the data and metadata.
Referring to
Referring again to
The first computing device generates a profile of the distribution channel based on the retrieved data and metadata (310). In one embodiment, the profile generator 204 executing on the machine 106 generates the profile. In another embodiment, the profile generator 204 retrieves data and metadata from the data aggregator 204. In still another embodiment, the profile generator 204 retrieves data and metadata from a database storing the data and metadata.
Referring now to
In some embodiments, the distribution channel profile 230 includes a description of at least one characteristic of the distribution channel that the profile generator 204 identified based upon an analysis of the retrieved data and metadata. In one of these embodiments, for example, the distribution channel profile 230 identifies a level of loyalty between a viewer of videos and the distribution channel based on a number of views by subscribers of distributed videos; the level of loyalty may be used in additional characteristics of the distribution channel, such as whether the distribution channel appeals to a particular demographic, is associated with a particular product or service brand, or is irrelevant, all of which may inform a decision to recommend one distribution opportunity over another. As another example, the distribution channel profile 230 identifies a level of importance of social sharing to viewers of videos on the distribution channel based on a number of social sharing operations. As another example, the distribution channel profile 230 identifies a level of engagement of viewers of videos on the distribution channel based on the number of social sharing operations. The retrieved data and metadata include, as described above (e.g., in connection with
Referring now to
Referring now to
Referring now to
Referring again to
The first computing device generates a recommendation for a method to increase a level of distribution of the video (312). In some embodiments, the recommendation engine 206 generates the recommendation. In one embodiment, the recommendation engine 206 generates the recommendation based at least in part upon an analysis of the profile of the video. In another embodiment, the recommendation engine 206 generates the recommendation based at least in part upon an analysis of the profile of the distribution channel.
In one embodiment, the recommendation engine 206 analyzes the profile of the video. In another embodiment, the recommendation engine 206 analyzes the profile of the distribution channel. In still another embodiment, a sub-component of the recommendation engine 206 performs the analyses (e.g., the profile analyzer depicted in shadow in
In one embodiment, the recommendation engine 206 identifies at least one channel adjacent to the distribution channel based, at least in part, on an analysis of at least one of the profile of the video and the profile of the distribution channel. In some embodiments, the recommendation engine 206 analyzes each piece of data aggregated by the data aggregator 202 in order to identify the at least one adjacent channel, iterating through the data. In one of these embodiments, the data aggregator 202 has already performed an initial analysis of the aggregated data and the recommendation engine 206 performs a second analysis. In another embodiment, the recommendation engine 206 identifies the at least one adjacent channel by executing a search of a second computing device (e.g., the video sharing network computing device 210, the social network computing device 212, or the search engine computing device 214) for channels associated with a characteristic identified in the profile of the video or associated with a characteristic identified in the profile of the distribution channel. In still another embodiment, a sub-component of the recommendation engine 206 identifies the at least one adjacent channel (e.g., the channel identifier depicted in shadow in
In some embodiments, the recommendation engine 206 identifies the at least one adjacent channel by analyzing a level of relatedness between the at least one adjacent channel and the distribution channel. In one of these embodiments, the recommendation engine 206 determines that a high degree of overlap exists between metadata associated with the two channels (e.g., the keywords, tags, demographic profile, or other metadata associated with the two channels). In another of these embodiments, the recommendation engine 206 determines that the at least one adjacent channel is related to the distribution channel based upon an explicitly defined relation, such as a subscription relationship between an owner of the distribution channel and the adjacent channel, or vice versa.
In some embodiments, the recommendation engine 206 identifies the at least one adjacent channel indirectly. In one of these embodiments, the recommendation engine 206 identifies a second video based on the analyses of the profile of the video and of the profile of the distribution channel. In another of these embodiments, the recommendation engine 206 identifies a second distribution channel associated with the second video.
In one embodiment, the recommendation engine 206 determines that the at least one channel adjacent to the distribution channel has at least one characteristic in common with the distribution channel. For example, the adjacent channel may have a common topic, theme, classification, or other characteristic in common with the distribution channel. In another embodiment, the recommendation engine 206 transmits an identification of the adjacent channel to the profile generator 204, which generates a profile of the adjacent channel; the recommendation engine 206 analyzes the generated profile of the adjacent channel to determine whether the adjacent channel has at least one characteristic in common with the distribution channel. In some embodiments, a sub-component of the recommendation engine 206 performs the analysis of the adjacent channel to determine whether the adjacent channel has at least one characteristic in common with the distribution channel (e.g., the channel analyzer depicted in shadow in
In one embodiment, the recommendation engine 206 determines that distributing the video on the adjacent channel could enhance a level of distribution of the video. In another embodiment, the recommendation engine 206 makes the determination based upon, without limitation, an analysis of the score for the adjacent channel as described above. In still another embodiment, and by way of example, the recommendation engine 206 may determine that the distribution channel and the adjacent channel are two separate channels but attract similar users, have similar themes, distribute videos or other data of similar content, or have another characteristic in common that would improve a level of distribution of the video. In another embodiment, the recommendation engine 206 determines that distributing the video on the adjacent channel would increase a number of viewers of the video. In still another embodiment, the recommendation engine 206 calculates a predicted increase in the number of viewers of the video based on previous viewer numbers of the adjacent channel and viewer numbers of comparable videos. In still another embodiment, the recommendation engine 206 determines that distributing the video on the adjacent channel would increase an amount of traffic to a web site associated with the video. In yet another embodiment, a sub-component of the recommendation engine 206 makes the determination and generates the recommendation based upon the determination (e.g., the recommendation generator depicted in shadow in
In one embodiment, the recommendation engine 206 may determine that placing an advertisement on the adjacent channel could enhance a level of distribution of the video. In another embodiment, the recommendation engine 206 may determine that promotion on a freely accessible social channel could enhance a level of distribution of the video. In still another embodiment, the recommendation engine 206 may determine that other forms of activity such as, without limitation, social interaction (e.g., commenting) and commercial distribution deals, could enhance a level of distribution of the video. In yet another embodiment, the recommendation engine 206 may identify an indirect form of activity that could enhance a level of distribution of the video such as, without limitation, video search engine optimization (SEO) in which revising keyword strategies to match strategies of the adjacent channel may enhance the level of distribution. In some embodiments, the recommendation engine 206 generates content and marketing ideas from the recommendation, going beyond simply identifying distribution opportunities. In one of these embodiments, by way of example, the recommendation engine 206 may determine, based at least in part on data identified by the system, that people interested in a particular product seem to like a particular type of content (e.g., without limitation, tutorial videos), and may determine to recommend the production of similar types of content. In yet another embodiment, the recommendation engine 206 may determine, based at least in part on data identified by the system, that people interested in a particular topic prefer videos of a certain length (e.g., without limitation, shorter clips of one minute or less, or longer educational content of 10 minutes of more) and may recommend the production of videos of a similar length. In yet another embodiment, the recommendation engine 206 may determine, based at least in part on data identified by the system, that people in a certain demographic group are interested in particular types of content. In some embodiments, the recommendation engine 206 may combine several of the identified factors, such as topics people are interested in, the demographic group they belong to, or products they are interested in, to determine what type of content these people prefer, or that these people prefer videos of a certain length.
The first computing device provides, to a user, the recommendation (314). In one embodiment, the machine 106 transmits the recommendation to the client 102 associated with the user (as shown in
Referring now to
In some embodiments, the recommendation interface 240 provides not just a recommendation but additional information underlying the decision to recommend a particular distribution opportunity. For example, the recommendation may include some or all of the information stored in a distribution channel profile 230 including, for example, a description of at least one characteristic of the distribution channel that the profile generator 204 inferred from retrieved data and metadata (such as brand loyalty, engagement, and influence).
Although described herein in connection with identifying distribution opportunities for videos, those of ordinary skill in the art will recognize that the methods and systems described herein may be used in connection with identifying distribution opportunities for other types of data. For example, the methods and systems described herein may be implemented to identify distribution opportunities for media objects generally. As one example, the methods and systems described herein may identify distribution opportunities for photographs, music, and other media objects.
Referring now to
A first computing device receives an identification of a media file and an identification of a distribution channel of the media file (402). As described above in connection with
The first computing device retrieves, from a media file sharing network, metadata associated with the media file (404). The first computing device may retrieve the metadata from the media file sharing network as described above in connection with
The first computing device retrieves, from a second computing device in a second network, data having at least one characteristic in common with the metadata (406). The first computing device may retrieve the data from the second network as described above in connection with
The first computing device generates a profile of the media file based on the retrieved data and the metadata (408). The first computing device may generate the profile as described above in connection with
The first computing device generates a profile of the distribution channel based on the retrieved data and the metadata (410). The first computing device may generate the profile as described above in connection with
The first computing device generates a recommendation for a method to increase a level of distribution of the media file (412). The first computing device may generate the recommendation as described above in connection with
The first computing device provides, to a user, the recommendation (414). The first computing device may provide the recommendation as described above in connection with
As indicated above, the functionality provided herein extends to identifying new audiences, not just new distribution channel; for example, as indicated above, the systems and methods described herein may provide functionality for identifying additional target segments. In some embodiments, the methods and systems described herein provide additional functionality for identifying target segments. An audience may include both distribution channels and target segments and the methods and systems described herein may use metadata about a video to identify the target segments. The methods and systems described herein may include additional functionality for identifying such target segments, as will be described in further detail below.
In some embodiments, instead of receiving an identification of a target segment and identifying adjacent target segments (as described above), the methods and systems described herein provide functionality for receiving a keyword and identifying a target segment. In one embodiment, a method for cross-platform target recommendation provides campaign creation and in-flight optimization. A cross-platform target recommendation may refer to a recommendation that identifies target segments across a plurality of social network platforms (which include, without limitation, file distribution platforms and other computer-network based platforms).
Referring now to
Referring now to
The method 600 includes receiving, by a first computing device, an identification of metadata of a media file, the received metadata including at least one keyword (602). The metadata may include, without limitation, keywords, phrases, consumer (e.g., buyer/customer) personas, and brand identifiers. The first computing device may receive this identification of metadata as described above in connection with
The method 600 includes directing, by the first computing device, a semantic engine to map the at least one keyword to a plurality of candidate target segments, each of the plurality of candidate target segments associated with one of a plurality of social network platforms (604). As indicated above, target segments may include psychographic, geographic, demographic, and/or behavioral target segments. The first computing device 106a may execute a semantic engine 502, or be in communication with a semantic engine 502, and use the semantic engine 502 to map the at least one keyword to the plurality of candidate target segments. In one embodiment, as will be understood by those of ordinary skill in the art, the mapping is a semantic (e.g., meaning-based) mapping between a semantic meaning of alphanumeric text of the at least one keyword and a semantic meaning of alphanumeric text describing each of the candidate target segments. As will be understood by one of ordinary skill in the art, the semantic engine 502 may have been trained on a generic document corpus (e.g., encyclopedia articles) and be able to identify other words or phrases that are associated with the keyword and may describe possible target segments within social networks (e.g., “college students,” “foodies,” “beauty products,” etc.). By way of example, and without limitation, the mapping may provide additional information about the relationship between the at least one keyword and the description of the one of the plurality of candidate target segments, such as, without limitation, any of the following types of relationships: “RelatedTo,” “IsA,” “PartOf,” “MemberOf,” “HasA,” “UsedFor,” “CapableOf,” “AtLocation,” “Causes,” “HasSubevent,” “HasProperty,” “MotivatedByGoal,” “ObstructedBy,” “Desires,” “CreatedBy,” “Synonym,” “Antonym,” “DerivedFrom,” “TranslationOf,” and “DefinedAs.” The semantic engine 502 may calculate the strength of associations between concepts (e.g., the keyword and the description of the candidate target segments) through the use of spreading activation methods, clustering methods, graph theoretic methods, supervised learning, or other methods or combinations of methods, as will be understood by those of ordinary skill in the art.
The method 600 includes providing, by the first computing device, access to an enumeration of the mapped plurality of candidate target segments (606). In one embodiment, upon receiving an identification of each of the plurality of candidate target segments from the semantic engine 502, the first computing device generates a listing of the plurality of candidate target segments for access by a user (e.g., for posting to a web page accessible by a client computing device 102 used by the user).
The method 600 includes receiving, by the first computing device, a user-generated identification of a subset of the plurality of candidate target segments (608). The first computing device may receive the user-generated identification in an electronic data transmission sent across a network 104 (e.g., a user of a client computing device 102 accesses the enumeration of the mapped plurality of candidate target segments via a network 104 and provides the identifications via the network 104).
The method 600 includes directing, by the first computing device, the semantic engine to strengthen an association between each of the identified subset of the plurality of candidate target segments and the at least one keyword (610). The method may further include providing, to the semantic engine 502, an identification of each of the subset of the plurality of candidate target segments. In some embodiments, the first computing device also directs the semantic engine 502 to weaken an association between the at least one keyword and a candidate target segment included in the original plurality of candidate target segments but not identified in the user-generated identification of the subset of the plurality of candidate target segments. Thus, the user-generated identification may be used to remove false positives and improve the mapping between keywords and target segments. In some embodiments, this results in a feedback loop to the semantic engine 502 the results in subsequent generation of improved recommendations for the purposes of identifying candidate target segments that increase a level of distribution of media files.
The identified subset may be referred to as a refined target segment. Further analysis of such refined target segments may be done to improve the identification of candidate target segments. By way of example, having mapped refined target segments back to the original keyword in effect creates target segment adjacencies both within and across multiple platforms (and within and across distribution channels within those platforms). As another example, in an embodiment in which the semantic engine 502 has mapped a particular refined target segment back to multiple keywords, in effect, results in a system in which the semantic engine 502 builds keyword adjacencies. With these adjacencies, the system 500 may learn from user selections of refined target markets (i.e. predicts whether user will select target segment or not). In some embodiments, the use of these adjacencies improves the process of generating recommendations for target segments. In some embodiments, the system further maps target segments in one platform to target segments in another platform, enabling improved identification of cross-platform target segments to recommend.
In one embodiment, a method includes generating a recommendation for a method to increase a level of distribution of the media file. The recommendation may include an identification of the selected target segment. The recommendation may include a display of an audience size for each selected target segment. The recommendation may include a display of a level of success each selected target segment has achieved in other distribution campaigns. The first computing device may generate this recommendation as described above in connection with
In some embodiments, the methods and systems described herein provide functionality for managing and optimizing cross-platform campaign spending. For example, in addition to using the methods and systems described herein to generate recommendations for increasing a level of distribution of a media file, the methods and systems described herein may provide functionality for implementing the recommendations. As another example, the methods and systems described herein may provide functionality for managing and optimizing cross-platform campaign spending, whether or not the campaign seeks to implement a recommendation for increasing a level of distribution of a media file across platforms. As above, platforms such as social network platform, file distribution platforms, and the like may be used to distribute media in a way that maximizes levels of distribution, viewership, or other factors. Audiences, as above, may include both target segments and distribution channels within and across platforms.
Referring now to
Referring now to
The method 800 includes receiving, by a first computing device, from a campaign manager, an identification of at least one campaign constraint in a campaign and an identification of at least one campaign objective (802). In one embodiment, the first computing device makes a web page available to a second computing device, from which the campaign manager specifies at least one campaign constraint in an advertising campaign. Campaign constraints may include, without limitation, a start date of a campaign, an end date of a campaign, a number of views desired during the campaign, and a budget for obtaining those views. Examples of objectives include click through rates and view rates.
The method 800 includes identifying, by a success metric engine executing on the first computing device, at least one key performance indicator associated with a bid in the campaign (804). In one embodiment, the success metric engine 704 identifies a predetermined set of key performance indicators (KPIs) to associate with the bid. In another embodiment, the success metric engine 704 derives the KPIs from the at least one campaign objective. In still another embodiment, the success metric engine 704 identifies the at least one key performance indicator by analyzing historical campaign data of campaigns having at least one characteristic substantially similar to the campaign and analyzing what KPIs were associated with the historical campaigns. Among other things, KPIs may include earned view rates. For example, in a video distribution platform, an opportunity to increase a level of distribution of a file (such as a file containing an advertisement) may include both paying for a distribution opportunity as well as organic opportunities for viewers to see the distributed file without the distributor having to pay.
The method 800 includes assigning, by the success metric engine, a weight to the at least one key performance indicator, the weight based on the at least one campaign objective (806). In one embodiment, the success metric engine 704 assigns the weight by determining how important the at least one key performance indicator is in accomplishing the at least one campaign objective and weighting the KPI accordingly. In another embodiment, the success metric engine 704 assigns the weight by analyzing historical campaign data of campaigns having at least one characteristic substantially similar to the campaign to determine how important a particular KPI was in accomplishing an objective of at least one historical campaign.
The method 800 includes determining, by the success metric engine, a level of likely success of accomplishing the at least one campaign objective based on the at least one key performance indicator and the weight (808). In one embodiment, the success metric engine 704 determines the score. In some embodiments, the success metric engine 704 applies a data normalization process to the KPI prior to the determination of the level of likely success. In one embodiment, the success metric engine 704 looks at a plurality of historical campaigns, creates a distribution of (historical) scores across the plurality of historical campaigns and performs statistical analyses to determine the level of likelihood of success in the current campaign.
The method 800 includes determining, by the campaign optimization engine, a bid amount for the bid, based upon the determined level of likely success of accomplishing the at least one campaign objective (810).
In some embodiments, the campaign optimization engine 702 and the success metric engine 704 determine bid amounts for a plurality of combinations of bids. In one of these embodiments, the campaign optimization engine 702 identifies a plurality of combinations of bids. In another of these embodiments, the campaign optimization engine 702 removes, from the plurality of combinations of bids, at least one combination of bids that fails to satisfy the at least one campaign constraint, resulting in a filtered plurality of combinations of bids. In still another of these embodiments, the success metric engine 704 determines a level of likely success for each of the filtered plurality of combinations of bids, based on at least one key performance indicator and at least one weight assigned to the at least one key performance indicator. In another of these embodiments, the campaign optimization engine 702 identifies a subset of the filtered plurality of bids having a level of likely success satisfying a predefined threshold level of success. In yet another of these embodiments, the campaign optimization engine 702 determines a bid amount for each of the identified subset of the filtered plurality of bids, based upon the determined level of likely success.
In some embodiments, the campaign optimization engine 702 adjusts a bidding prediction (e.g., determined likelihood of success and bid amount) based on a day of the week or other characteristic of the campaign. As mentioned above, the campaign optimization engine 702 may be optimizing a campaign having an objective of increasing a level of distribution or actual viewings of a file (such as, without limitation, a static or dynamic advertisement) and may be doing so across a plurality of network platforms (e.g., a plurality of social media sites, video distribution sites, media distribution or file sharing sites, microblogging or blogging sites, or other network platforms); therefore, the campaign optimization engine 702 may optimize the campaign, including adjustments to bidding predictions, based on characteristics of the platforms on which the file is available.
Different types of constraints and objectives may be categorized as different types of deals, each of which may involve application of different functionality for optimizing the campaign. For example, a campaign with an objective for achieving a particular number of views during the campaign may be described as a “views deal,” while a campaign focusing on remaining within a particular budget may be described as a “spend deal,” and campaigns with combinations of constraints and objectives may be described as “hybrid deals.” In an embodiment in which the system receives an identification of a views deal, the system may determine to implement a strategy to achieve a specific level of views in a given timeframe and the system may take the risk of acquiring the inventory to deliver the views, without evaluating a level of spending. In an embodiment in which the system receives an identification of a spend deal, the system may adjust its recommendations and optimizations to target a particular level of spending over the course of the campaign, instead of optimizing to achieve a number of views by a particular period of time. As another example, the system may optimize a pacing of spending for a particular type of deal by taking an unintuitive, counterintuitive, or nonobvious step, such as recommending increased spending during particular periods in the campaign, or purchasing of more expensive distribution opportunities, even in a spend deal where aggressively managing costs over the course of the campaign may be the intuitive approach. By implementing counterintuitive strategies for “pacing ahead” (instead of a conventional approach of evenly dividing an amount to be spread over a length of time of the campaign), the system may achieve multiple objectives for a variety of campaign types. The system may analyze a plurality of previous campaigns having similar key performance indicators or other characteristics in common with the campaign being optimized to determine whether and how to optimize the current campaign and may do so a plurality of times in real time (e.g., during the course of optimizing the current campaign).
In some embodiments, the system may control how the campaign optimization engine 702 distributes a level of spending across distribution groups across a campaign. In contrast to a conventionally managed campaign, in which campaign managers do not typically have functionality for spreading views across a plurality of groups receiving an advertisement in a campaign and in which the campaign managers are not typically able to specify more granularity than that they desire a certain number of views total, the methods and systems described herein provide functionality for distributing a number of views across a plurality of advertising groups, so that there is a spread parameter that sets a minimum number of views in each of a plurality of advertising groups. By way of example, and without limitation, a spread parameter of 1 will evenly divide a day's needed views (e.g., a number of views needed in order to satisfy a campaign objective of a particular total number of views) across the ad groups and remove from the pool of options any bid level that goes below that threshold, unless all of them do, and then it keeps the highest option; a spread parameter of 0.5 will use half of that threshold value as its minimum.
The system may further include functionality for limiting the ability of the campaign optimization engine 702 to complete a campaign objective before a scheduled completion date. For example, if a campaign was scheduled to run for a week, month, or any other period of time specified as a campaign constraint, but the campaign optimization engine 702 could deliver the identified campaign objectives in half that time, there may be business reasons for preventing the campaign optimization engine 702 from delivering the campaign objectives before the completion of the campaign—for example, and without limitation a campaign manager may have specified that a specific number of views were the objective but may also have had unspecified objectives, such as wanting to have distribution of the ad over a course of time (e.g., over the course of series of public events scheduled to last for the length of the campaign); if the campaign optimization engine 702 delivered the stated objective of a particular number of views before the end of the campaign, the campaign manager might actually be dissatisfied with the optimization. Therefore, in contrast to a conventional system, the system may include functionality for forcing the campaign optimization engine 702 to perform less aggressively or in a less optimal manner, weighting short term objectives (such as selection of a more optimal campaign over a less optimal campaign) less than long term objectives (such as having the campaign last for a predetermined period of time), in order to meet more objectives, including potentially unstated user expectations or potentially unidentified objectives. In some instances, for example, the system may program the campaign optimization engine 702 to both identify a combination of bids that fails to satisfy the at least one campaign constraint and to include the combination of bids in the campaign (e.g., including a distribution plan that targets a demographic group that the campaign optimization engine 702 determines will not increase a number of views in order to satisfy an unstated user expectation that the demographic group would be include or to avoid completing the campaign too promptly).
The methods and systems described herein may further provide functionality for controlling how far or behind an optimal level of pacing of spend or views the campaign optimization engine 702 should be at any point in time during a campaign. By way of example, instead of determining that to achieve a number X of views over a particular campaign the campaign optimization engine 702 should divide the number by the total number of days Y in the campaign (e.g., X divided by Y) and achieve that amount of views each day (or similarly for a spend deal, achieve a certain amount of spending each day in a campaign by dividing the total budget by the number of days), the campaign optimization engine 702 may be programmed to instead front load an objective—spending more or achieving more views at the beginning of a campaign time period, setting an ideal pacing level to be slightly above a linear pacing line. When campaigns are ahead of linear pacing (e.g., have achieved more objectives than what would have been achieved using a linear pacing approach), by increasing a target to be above a linear pacing line the target is closer to how the campaign is actually performing, which also helps provide a buffer making the campaign more likely to stay above the linear pacing line, and thus more likely to achieve one or more campaign objectives. Cubic spline pacing may be achieved by setting the campaign optimization engine 702 such that one third of the way through a campaign, the campaign is 10% ahead of a level of progress that would have been achieved with linear pacing; such pacing may of course be adjusted and the system may include a user interface for adjusting it.
In some embodiments, the system includes improved functionality for recovering from a failure to achieve an objective. For example, in conventional systems when a campaign has overspent its budget before the end of a campaign, a campaign manger's only option may be to stop spending (typically resulting in a failure to distribute a file such as an advertisement for the remainder of the campaign). In contrast, the campaign optimization engine 702 may be configured to counter-intuitively continue spending but to modify the amount of spending until it has corrected for the previous level of spending. By way of example, rather than flat-lining (e.g., not spending anything as soon as the overspending is identified), the campaign optimization engine 702 may enable over-paced (e.g., over-spent) campaigns to keep spending by changing an on-pace time-frame objective—instead of aiming to get back on track within the minimum amount of time possible, the system adjusts spending so that spending is on track by the end of the campaign, trading off margin for continuous ad delivery, although this runs counter-intuitive to conventional approaches.
It should be understood that the systems described above may provide multiple ones of any or each of the described components and that these components may be provided on either a standalone machine or, in some embodiments, on multiple machines in a distributed system. It should also be understood that phrases such as “based on” and “based upon” do not imply “based exclusively on” and instead generally mean that the particular feature, structure, step, or characteristic is based at least in part on the specified element. Further, the phrases ‘in one embodiment,’ ‘in another embodiment,’ and the like, generally mean that the particular feature, structure, step, or characteristic following the phrase is included in at least one embodiment of the present disclosure and may be included in more than one embodiment of the present disclosure. However, such phrases do not necessarily refer to the same embodiment.
The systems and methods described above may be implemented as a method, apparatus, or article of manufacture using programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output. The output may be provided to one or more output devices.
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be LISP, PROLOG, PERL, Python, C, C++, C#, JAVA, or any compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of computer-readable devices, firmware, programmable logic, hardware (e.g., integrated circuit chip; electronic devices; a computer-readable non-volatile storage unit; non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs). Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium. A computer may also receive programs and data (including, for examples, instructions for storage on a non-transitory, computer-readable media) from a second computer providing access to the programs and data via a network transmission line, wireless transmission media, signals propagating through space, radio waves, infrared signals, etc.
Having described certain embodiments of methods and systems for identifying cross-platform audiences and optimizing campaigns, it will now become apparent to one of skill in the art that other embodiments incorporating the concepts of the disclosure may be used. Therefore, the disclosure should not be limited to certain embodiments, but rather should be limited only by the spirit and scope of the following claims.
This application claims priority from U.S. Provisional Patent Application Ser. No. 62/403,367, filed on Oct. 3, 2016, entitled “Methods and Systems for Identifying Cross-Platform Audiences and Optimizing Campaigns,” which is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
62403367 | Oct 2016 | US |