1. Field of the Invention
The present invention relates generally to social networking, and more particularly to systems and methods for auction based polling.
2. Description of Related Art
Conventionally, survey firms provide various conduits for companies to survey individuals in a public or private arena. With the popularity of the Internet and online venues, these survey firms often survey individuals via the Internet. A company or individual can pay the survey firms to survey these individuals, groups, and so forth using a variety of media outlets available online.
Typically, the survey firm accrues results from polls taken on behalf of the company or the individual and provides the results to the company or the individual. The results may be provided based on information input by the company or the individual or according to any other criteria. The survey firm may also provide demographic data about the users that participated in the polls.
However, the company or the individual that requested the poll sometimes desires faster and event nearly immediate results. In addition, a lengthy, typically offline, registration process with the survey firm is often involved for scheduling the polls. Further, the survey firm, rather than a poll requester, frequently specifies a price for the poll.
The present invention provides a system and method for auction based polling. Parameters related to a poll are received from a first user. A query is associated with the poll. A priority of the poll is determined based on the parameters. The poll is distributed to one or more second users according to the priority. Results to the poll are gathered. The results are reported to the first user.
The users 102 may access the polling engine 106 via a computing device, such as a laptop or desktop computer, a cellular telephone, a personal digital assistant (PDA), a set top box, and so forth. The users 102 may view data about social network members, enter data about the users 102, themselves, join social network groups, and so forth, via the polling engine 106. The users 102 are typically members of a social networking website associated with the polling engine 106, for example, and thus comprise the social network members, themselves. However, any of the users 102 or other individuals not associated with the polling engine 106 can conduct a poll or survey of the members of the social networking website by interfacing with an application programming interface (API) 108 associated with the polling engine 106. For example, the users 102 that are non-members of the social networking website may conduct polls of the users 102 that are members of the social networking website and the users 102 that are members of the social networking website may also conduct polls of the users 102 that are also members of the same social networking website.
In other embodiments, the users can access the polling engine 106 via an advertising engine (not shown) that serves advertisements to various users. Any type of website, network, and so forth may connect the users 102 with the polling engine 106.
The users 102, such as the users A 102A through users N 102N, may generate polls utilizing the polling engine 106. According to some embodiments, a user accesses the polling engine 106 via the API 108, such as via a website hosted by the polling engine 106. The user enters data into the API 108, such as desired questions, for conducting a poll, survey, or any other type of query of the users 102 associated with the polling engine 106. The API 108 may be provided specifically for queries or polls, or in alternative embodiments, for various other interactions with the polling engine 106 as well.
The user accessing the API 108 can also enter auction data. For example, the user 102 (i.e. the poll requester) can specify a price per answer the user 102 is willing to pay for answers to the survey, poll, or query. The polling engine 106 can rank the poll from the poll requester against other requested polls according to the price per answer and fulfill the polls according to the bids (i.e., the price per answer). In some embodiments, a hierarchy may be assigned to the polls according to the bids. Alternatively, some polls may not be fulfilled according to the bids.
In some embodiments, the poll requester can, more specifically, bid the price per answer for varying categories or groups of the users 102 associated with the polling engine 106. For example, the price per answer for computer science majors from MIT may be higher than the price per answer for computer science majors from Harvard. Any type of grouping or categories for potential survey recipients is possible. The poll requester may specify the categories or the polling engine 106 may suggest categories. The categories associated with the users 102 may be selected from a drop down menu or other menu offering predetermined categories of the users 102, or by any other means known in the art.
Various methods of providing poll details to the polling engine 106 may be employed. The poll requester may enter a poll question and response choices, fir example via a web page. Alternatively, the polling engine 106 may provide the API 108 for users to write programs and generate polls, themselves, to automatically base decisions on poll results and/or generate new polls based on the results of one or more previous polls.
The poll requester may also be able to enter data regarding what the poll requester is willing to pay to conduct the poll via the API 108, thus creating an auction-like process. For example, the poll requester can specify a bid per answer, a bid per user, and/or a bid per impression that the poll requester is willing to pay. The bid per user may include a price per grouping or type of user, such as users from a particular geographical location or school. The bid per impression may include a price per instant the poll appears to the users 102 or a group of the users 102.
The bid may be based on profiles associated with the users 102. As discussed herein, the users 102 that are members of the social networking website may be polled by other members and/or by the users 102 that are non-members. For example, the poll requester may bid a dollar ($1.00) for answers by the users 102 who indicate in a profile that the users' 102 favorite food is pizza. Bid types may be combined according to some embodiments. For example, the poll requester may bid one dollar ($1.00) for each answer and another one dollar ($1.00) for each impression related to the users 102 that attend Stanford University. Any type of combination of bidding methods is within the scope of the present invention.
The polling engine 106 can rank all polls requested according to the price per answer or impression and fulfill the polls according to the bids (i.e., the higher priced polls first). Priority may alternatively be based on total cost, regardless of the number of requested users. Any type of hierarchy or priority may be calculated utilizing any data available to the polling engine 106.
According to some embodiments, the polling engine 106 can determine a predicted response rate to the poll. The predicted response rate may be utilized by the polling engine 106 to select the polls that win an auction. For example, a poll with a high predicted response rate may be more desirable because the poll may generate more revenue than a poll that is predicted to have a low response rate.
Referring now to
Typically, the users 102 may access a website associated with the polling engine 106. For example, the polling engine 106 can host the social networking website which the users 102 can visit to interact with one another. The website can display various types of data about the users 102 to one another, such as profile information, relationships between users, poll results, and other information. The users 102 may belong to particular communities within the social networking website, such as communities categorized according to school attended, workplace, geographical location, etc. The communities may be utilized by the polling engine 106 for grouping or categorizing the users 102. As discussed herein, different bids may be provided by a poll requester for the different communities comprised of the users 102.
A parameter module 204 is provided for receiving parameters associated with a requested poll via the API 108. The poll requester inputs various desired parameters, such as a price per answer, price per impression, price per type of user, questions for the poll, and so forth.
An auction module 206 is provided for evaluating the bids entered by the poll requester. The auction module 206 can compare the various parameters input to determine a hierarchy for fulfilling the polls from each of the poll requesters. The auction module 206 may fulfill polls in an order based on the bid per answer, the bid per impression, the bid per type of user, a combination of types of bids, and so forth.
The total amount of each bid may also be considered. For example, a user X may bid ten dollars ($10.00) per answer for a maximum of 100 answers while a user Y bids five dollars ($5.00) per answer for a maximum of 300 answers. The auction module 204 may then rank user Y's bid as higher because the net bid is higher than user X's bid (i.e., $1500 net rather than $1000). Any type of ranking system may be employed by the auction module 204. For example, the polls may be ranked according to price, difficulty of gathering responses or fulfilling the poll, originality of poll, and so forth. Further, as discussed herein, different bids for different type of users responding to the poll may be entered.
A query module 208 conducts the polls by sending out queries to the users 102 and gathering responses from the users 102. The query module 208 may fulfill the polls in an order specified by the auction module 206.
If desired, the query module 208 may suggest follow up or alternative poll-related queries to the poll requester. For example, based on responses from the users 102 to the polling queries, the polling module 206 may suggest other poll categories or subject matter in which the users 102 may be interested. The query module 208 may also suggest alternative language for posing poll related queries to the users 102 based on information about the users 102, such as previous polling responses, user profile data, and so forth.
A reporting module 210 utilizes the polling responses gathered by the query module 208 to generate a report for the poll requester. The reporting module 210 may access profile data for the users 102 that responded to the poll to generate the report and/or any other type of data. The report may include demographics about the users 102 that responded, for example.
A profile database 212 that includes information about the users 102 may need to be accessed by the reporting module 210 and/or the query module 208 according to some embodiments. For example, the profile database 212 may be utilized in order to access and provide demographic information about the users 102, to help the query module 208 determine which of the users 102 should receive a query, and so forth. Access to data about the users 102 or to the users 102, directly, may be restricted by the polling engine 106. Thus, the polling engine 106 may provide only certain demographic data to the poll requester about the users 102 that respond to polls.
The poll may be sent to specific users 102 or the poll may be posted on a social networking website associated with the polling engine 106. If the poll is posted rather than sent, the users 102 that respond to the poll may need to be compared with profile data to determine if the users 102 meet the parameters specified by the poll requester, such as female MIT students. For example, the parameter module 204 may ignore responses from the users 102 identified through profile information as graduates of Harvard if the poll requested that only students from MIT respond to a posted poll.
Although
Referring now to
One or more answer choices 308 for the poll 302 may also be input by the user, as shown on the poll creation screen 300. For example, as shown in
The poll requester can further select one or more targets 310 for desired respondents by indicating an age range and/or sex associated with the polled users. The age range may be predetermined and selected from a drop down menu or the poll requester may specify a custom age range, one or more specific ages, and so forth. According to some embodiments, the poll requester can identify keywords or profile types that the poll requester wishes to target with the poll being requested.
The poll requester can also select a location 312 to associate with the poll 302. For example, the poll related to the “upcoming election” in the screen shown in
A number of desired responses 314 may be selected or input by the poll requester. The number of responses 314 can identify the maximum number of the responses needed. A minimum number of responses or a range of acceptable responses may also be selected according to some embodiments. The poll requester may identify a number of responses required for a group of polls and allocate an ideal number of responses for each poll within the group of polls. Groups of polls may be distinct from one another or related. For example, the users 102 that select “Hillary Clinton” in the “upcoming election” poll 302 may also be queried regarding campaign funding in a related poll, while favorite cereal types may be queried in a different poll. Any group of polls may be requested related to any common area or range of subject matter.
A duration of the poll may also be selected according to some embodiments. The duration may be specified by the polling engine 106 or may be requested by the poll requester and may be in terms of real time, number of responses, or a combination. For example, the polling engine 106 may indicate that it is likely to take four hours to complete a poll for which a maximum of 400 answers is desired by the poll requester. In another example, the poll requester may request completion of the poll within 3 hours, or any other increment of time. The polling engine 106 may estimate the amount of time it takes to gather the answers based on previous polls, for example. The duration of the poll may be correlated with bid prices, so that polls with higher bids receive faster results. Any method for estimating the amount of time needed to gather answers to a poll is within the scope of various embodiments.
As discussed herein, a bid price 316 for each of the responses 314, a bid per user, and/or a bid per impression, may also be selected or bid by the poll requester. The price for each response, each of the users 102, and/or each impression may be multiplied by the number of responses desired for a total bid price. As discussed herein, any of these numbers may then be utilized by the polling engine 106 to determine which polls requested are fulfilled. The requested polls may be fulfilled in a hierarchical order according to the bid price, such as in an auction using either a per user price or the total price. According to some embodiments, only the poll with the highest bid price is fulfilled within a certain period of time, such as every hour or every day. Polls with lower bids may thus take longer to fulfill than the polls with higher bids. However, other criteria, such as subject matter, affiliation with the network, and so forth may also be utilized to decide when to fulfill one or more polls in addition to the auction of the bids per answer, per user 102, per impression, etc. For example, an advertiser that often advertises with a particular website may have the advertiser's polls prioritized based on affiliation with the particular website and/or a high price bid per impression, or a price for each impression to targeted users.
According to some embodiments, the poll may be prioritized based on a combination of the level of a bid and the expected time for performance of the poll. Thus, a poll that the polling engine 106 expects will receive the maximum number of responses easily may be ranked higher due to the ability to easily fulfill the poll while a poll in which the maximum number of responses will be difficult or more time consuming to obtain may be ranked lower due to the difficulty of fulfilling the poll. As discussed herein, any criteria may be utilized to rank or prioritize various polls.
After the poll requester completes the order and bid for the poll, the poll requester can select a “finish and pay” button, or any other mechanism for submitting the order. Although the poll creation screen 300 illustrates various options for providing a poll query, answers to the poll query, target audience, location, and bids, less or more information may be provided via the poll creation screen 300 and still fall within the scope of various embodiments.
According to some embodiments, a bid for the poll may be declined. For example, a poll associated with a higher bidder may be chosen by the polling engine 106 over a lower bidder for the same or similar poll. A screen may be displayed that indicates to the poll requester that the poll request cannot be fulfilled, the poll request is declined, or any other desired message. Any type of process, display, etc. for accepting or declining poll order requests is within the scope of various embodiments.
If the poll requester wishes edit the details of the poll, the poll requester may return to the poll creation screen 300 from the order confirmation screen 400 to edit the details of the poll 302. Any other mechanism for editing the poll, such as a pop up window, may alternatively be provided.
Payment information 404 may also be provided via the order confirmation screen 400. Although the order confirmation screen 400 in
As discussed herein, the poll requester may indicate groups of users 102 to which the poll 302 should be sent or targeted. Although
At step 504, an indication of a desired population to provide answers to the poll is received, such as the targets 310 discussed in
At step 506, the polling engine 106 receives a bid amount that the poll requester is willing to pay. The poll requester may be willing to pay per user, per impression, and so forth, as discussed herein.
At step 508, the polling engine 106 specifies the bill total for the poll requester based upon the bid amount. As discussed herein, the bid may vary for different bid types. The poll requester may specify different bids for different user types answering the same poll. The polling engine 106 may fulfill and/or prioritize the poll based on the various bid types. For example, different types of impressions, users, and so forth may be bid differently by the poll requester. As discussed herein, MIT students that provide answers may be paid for at a higher rate than Harvard students. Similarly, the price per answer when the poll is accessed from a central social networking page associated with a social networking website may be higher than when the poll is accessed via an advertisement associated with the social networking website. Any type of bids based on any type of data, grouping, and so forth may be entered by the poll requester or provided as a selection by the polling engine 106.
At step 510, the billing information is received. At step 512, the poll is prioritized and fulfilled. The results of the poll are then reported in real-time to the poll requester, at step 514. According to some embodiments, the results of the poll may be reported to other users 102, such as users that recently answered the poll question, users visiting a screen on which the poll question is displayed for answer, and so forth. The poll requester and/or the polling engine 106 can determine which users 102 can access the poll results, according to some embodiments. Although step 514 indicates that the poll results are reported in real time, the poll results may be reported to the poll requester or any other users 102 at any point in time, according to other embodiments.
Also discussed herein, the first user may comprise a member of the social network or any other user. The first user may request the poll via the poll creation screen, as shown in
At step 604, a query is associated with the poll. The poll requester may associate one or more queries with the poll, as shown in
At step 606, a priority of the poll is determined based on the parameters. A poll may be fulfilled before another poll or conducted instead of another poll based on the parameters. For example, the polling engine may gather and return results to the requester with the highest bid per answer before other poll results are returned to other requesters.
The priority of a poll may change depending upon the particular poll and the parameters. For example, based on parameters including response rates to the particular poll, the priority of the particular poll may change as it is conducted by the polling engine. Priority may also be calculated on a per user basis, as discussed herein, such as when the polling engine determines that certain users are more likely to respond to some polls.
At step 608, the poll is then sent to one or more second users, such as the users associated with a social networking website, according to the priority. The first user may comprise the poll requester, as discussed herein, that belongs to a network in common with the one or more second users or the first user may not be associated with the network. In other words, any user can request a poll, whether or not the user is associated with the one or more second users via a common network, a common website, and so forth.
An incentive may be provided to the users for answering the one or more queries associated with the poll. For example, the users may receive points, coupons, and so forth for answering the queries associated with the poll. The queries associated with the poll may be nested according to some embodiments. In other words, if the user selects choice #3, the user may be asked another query related to the choice #3. For example, in
The poll may be sent to individual users; such as via email or posted or displayed to profile pages associated with each of the individual users, and/or the one or more queries may be displayed to a common area associated with a website. When the queries are displayed in a common area, the polling engine may compare the users that answer the poll with a profile associated with each of the users when a specific type of user is desired. For example, if the poll indicates that only blue-eyed users should answer, the polling engine may compare the users that answer the poll with their profiles to ensure that they have blue eyes and disregard answers from other users. In other embodiments, the polling engine may indicate to the users a group that is desired to answer the poll and may either prevent other users from answering the poll at all or not register the users' answers.
According to other embodiments, the users to which the poll is distributed may be balanced based on an automated sample balancing, so that the users are representative of a population of users being sampled.
At step 610, results to the poll may then be gathered. As discussed herein, the results may be gathered over any period of time. The results may be gathered according to a “winner” of the auction or according to any other criteria, as discussed herein.
At step 612, the results are then reported to the first user, such as the poll requester. The results may be categorized according to demographics, target audience, answer types, and so forth. Any data may be provided with the raw answers. According to some embodiments, the answers may be utilized to automatically generate other polls or queries.
The results may be reported to the poll requester in real-time or according to any other method. The raw answers may be reported in real-time while analytical data associated with the raw answers are reported at a later time. Any type of results may be reported to the poll requester in real time.
According to some embodiments, a user that answers the query associated with the poll can access the results of the poll gathered up to the time the user answers or a subset of the results to the poll. As discussed herein, polls may be automatically generated based on answers to previous polls. In some embodiments, the poll requester can schedule polls to run automatically at various intervals and to update the polls based on previous poll results, if desired. As also discussed herein, the priority of a poll may change as the poll runs its course. The polling engine can provide previous poll results to the poll requester based on similarity of the poll requested to other polls previously conducted, according to some embodiments. Polls can be delivered in any manner, as discussed herein, such as posted to a page, delivered with advertisements, accompanying a news story, and so forth.
The above-described components and functions can be comprised of instructions that are stored on a computer-readable storage medium. The instructions can be retrieved and executed by a processor. Some examples of instructions are software, program code, and firmware. Some examples of storage medium are memory devices, tape, disks, integrated circuits, and servers. The instructions are operational when executed by the processor to direct the processor to operate in accord with the invention. Those skilled in the art are familiar with instructions, processor(s), and storage medium.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. For example, any of the elements associated with polling engine 106 may employ any of the desired functionality set forth hereinabove. Thus, the breadth and scope of a preferred embodiment should not be limited by any of the above-described exemplary embodiments.
The present application claims the priority benefit of U.S. patent application Ser. No. 60/932,712, filed May 31, 2007, titled, “Systems and Methods for Auction Based Polling,” which is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5905975 | Ausubel | May 1999 | A |
5937413 | Hyun | Aug 1999 | A |
6021398 | Ausubel | Feb 2000 | A |
6029141 | Bezos | Feb 2000 | A |
6477504 | Hamlin et al. | Nov 2002 | B1 |
6513014 | Walker et al. | Jan 2003 | B1 |
6539392 | Rebane | Mar 2003 | B1 |
7013292 | Hsu | Mar 2006 | B1 |
7249123 | Elder | Jul 2007 | B2 |
7269590 | Hull | Sep 2007 | B2 |
7711587 | De Marcken | May 2010 | B2 |
20010032132 | Moran | Oct 2001 | A1 |
20010032133 | Moran | Oct 2001 | A1 |
20010037721 | Hasegawa | Nov 2001 | A1 |
20020059201 | Work | May 2002 | A1 |
20030009362 | Cifani et al. | Jan 2003 | A1 |
20030078804 | Morrel-Samuels | Apr 2003 | A1 |
20030145093 | Oren | Jul 2003 | A1 |
20030222918 | Coulthard | Dec 2003 | A1 |
20030225632 | Tong | Dec 2003 | A1 |
20040024846 | Randall | Feb 2004 | A1 |
20040088177 | Travis | May 2004 | A1 |
20040148275 | Achlioptas | Jul 2004 | A1 |
20050021750 | Abrams | Jan 2005 | A1 |
20050055306 | Miller et al. | Mar 2005 | A1 |
20050075919 | Kim | Apr 2005 | A1 |
20050114759 | Williams | May 2005 | A1 |
20050154639 | Zetmeir | Jul 2005 | A1 |
20050159970 | Buyukkokten | Jul 2005 | A1 |
20050171799 | Hull | Aug 2005 | A1 |
20050171955 | Hull | Aug 2005 | A1 |
20050177385 | Hull | Aug 2005 | A1 |
20050197846 | Pezaris | Sep 2005 | A1 |
20050198020 | Garland | Sep 2005 | A1 |
20050198031 | Pezaris et al. | Sep 2005 | A1 |
20050198305 | Pezaris | Sep 2005 | A1 |
20050203807 | Bezos | Sep 2005 | A1 |
20050216300 | Appelman | Sep 2005 | A1 |
20050216550 | Paseman | Sep 2005 | A1 |
20050235062 | Lunt | Oct 2005 | A1 |
20050256756 | Lam | Nov 2005 | A1 |
20060041543 | Achlioptas | Feb 2006 | A1 |
20060042483 | Work | Mar 2006 | A1 |
20060048059 | Etkin | Mar 2006 | A1 |
20060052091 | Onyon | Mar 2006 | A1 |
20060080221 | Murakami | Apr 2006 | A1 |
20060080613 | Savant | Apr 2006 | A1 |
20060085419 | Rosen | Apr 2006 | A1 |
20060136419 | Brydon | Jun 2006 | A1 |
20060143183 | Goldberg | Jun 2006 | A1 |
20060161599 | Rosen | Jul 2006 | A1 |
20060178193 | Hunter | Aug 2006 | A1 |
20060184417 | Van der Linden et al. | Aug 2006 | A1 |
20060184617 | Nicholas | Aug 2006 | A1 |
20060190281 | Kott | Aug 2006 | A1 |
20060194186 | Nanda | Aug 2006 | A1 |
20060218225 | Hee Voon | Sep 2006 | A1 |
20060229063 | Koch | Oct 2006 | A1 |
20060230061 | Sample | Oct 2006 | A1 |
20060247940 | Zhu | Nov 2006 | A1 |
20060248573 | Pannu | Nov 2006 | A1 |
20060256008 | Rosenberg | Nov 2006 | A1 |
20060265227 | Sadamura | Nov 2006 | A1 |
20060293976 | Nam | Dec 2006 | A1 |
20070174389 | Armstrong | Jul 2007 | A1 |
20070192166 | Van Luchene | Aug 2007 | A1 |
20070208916 | Tomita | Sep 2007 | A1 |
20070233503 | Meyer et al. | Oct 2007 | A1 |
20070282987 | Fischer | Dec 2007 | A1 |
20080005076 | Payne | Jan 2008 | A1 |
20080010343 | Escaffi | Jan 2008 | A1 |
20080033776 | Marchese | Feb 2008 | A1 |
20080040428 | Wei | Feb 2008 | A1 |
20080070697 | Robinson | Mar 2008 | A1 |
20080086458 | Robinson | Apr 2008 | A1 |
20090055268 | Knoller et al. | Feb 2009 | A1 |
20090076914 | Coueignoux | Mar 2009 | A1 |
20100138291 | Silverman et al. | Jun 2010 | A1 |
20100146416 | Palmer | Jun 2010 | A1 |
20110184780 | Alderson et al. | Jul 2011 | A1 |
Number | Date | Country | |
---|---|---|---|
20090037277 A1 | Feb 2009 | US |
Number | Date | Country | |
---|---|---|---|
60932712 | May 2007 | US |