There are a number of techniques used by match making systems (e.g., online match making systems) to match people. One technique is to use specified preferences and provided demographics to match people. For example, one person may specify he is interested in women who live within 10 miles, with black hair, ages 35-45, and who are college graduates. The system then matches that person with people based on the information each person in the system provides (e.g., about their gender, residence, physical description, age, education, etc.). Another technique is to match people based on psychographic data. In some cases (e.g., used by eHarmony.com) specified preferences and psychographic data are used to make matches. Using the psychographic data, the system selects matches based on an estimated satisfaction.
In some cases, one or both of the people in a match do not respond positively to the other person. For example, a match making system may make 10 matches for a user and sends information about the 10 selected match candidates to the person being matched. In some cases, the person being matched reviews the information (e.g., a picture, a self-description, etc.) but decides not to contact one or more of the selected match candidates. Some or all of the matches are thus underutilized or are “wasted.” In some cases, two people who are matched contact each other but decide not to pursue further contact (e.g., after a written exchange, a telephone call, or an in-person meeting). It would be desirable if new techniques were developed in which the person being matched is more likely to reach out to the selected match candidates and/or the matched people are more likely to continue contacting each other after an initial in-person meeting or other form of contact.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
In various embodiments, network 104 includes a variety of technologies, protocols, or networks such as wired/wireless networks, mobile or cellular voice or data networks, broadband networks, Internet or web related protocols, etc. Although this example shows computers, in other embodiments, users of a system connect to and/or communicate with a matching service via some other device or communication channel (e.g., a mobile telephone, letters exchanged via mail, etc.).
In this example, the matching service is web-based. For a particular person being matched, server 102 selects one or more match candidates. Once the matches are determined, the person being matched is notified about their matches and some information about the selected match candidates is provided. In one example, no picture is provided to the person being matched and the person decides whether to communicate with a particular person based on other information, such as a brief description written by that person. In some embodiments, the selected match candidate is also made aware of the person to whom they have been matched. In some embodiments, communication between two matched people is facilitated or otherwise managed by matching service 104. For example, the people may be required to login to a website, submit a message, and return later to access a response (if any).
The lifecycle of a user (also referred to as a member) starts when a person joins a matching service. For example, a user may sign up as a member of eHarmony.com. As a user, the person is both a person being matched and a match candidate for other users. In one example, a matching service agrees to provide 10 matches and additional matches can be made for additional fees. The lifecycle of the user ends when the user leaves the matching service because, for example, that person has entered a committed relationship or the user no longer desires the services of the match making system.
Over the lifecycle of a user, server 102 collects a variety of information about the user. In some embodiments, server 102 records which selected match candidates a particular person decides to contact. For example, a person may be matched with 10 people but only contacts 6 of the 10 people. In some embodiments, server 102 records a response or rating associated with how much a person likes another person to whom they have been matched with. In one example, this response or rating is after contact with a person, such as an in-person meeting, a telephone call, or a written exchange. In another example, the response or rating is prior to contact with the person and is in response to a person's profile, picture, description, etc.
In general, collaborative filtering is technique that collects a repository or other (relatively large) collection of response information and makes matches based on the collected information. By using a collection of known or historic response information to make matches, the likelihood of a positive response by a user of the system to newly made match is improved. In some embodiments, statistical techniques are used to determine similar users and make matches based on previous matches for those similar users.
This figure and other figures are merely examples and other embodiments may vary from the examples shown herein. For example, although this example shows a woman as the person being matched and men as the match candidate(s), some other embodiments have different gender combinations (e.g., men/women, women/women, and men/men).
Response repository 202 is configured to store response information from users and manage that information as appropriate. For example, if the system is configured to ask a user for a rating or response after two people have contacted each other, that rating or response is stored in response repository 202. In some embodiments, response repository 202 monitors and stores which selected match candidates a user contacts and/or which match candidates a user has been matched with but did not contact. In various embodiments, the form of a response or rating is expressed as a number (e.g., an integer between 1 and 10), a qualitative description (e.g., “I really liked that person,” “I sort of liked that person” or “I did not like that person”), or a state (e.g., “Contact,” “Did not contact,” or “No information”). In this example, response repository 202 stores the person from whom a response is received or who generated the response information and the person to whom the response or ranking pertains to. For example, suppose the two people shown in
In various embodiments, a response repository supports various functions or commands for searching, adding, deleting, manipulating, or otherwise accessing information stored within a response repository. Correlation engine 204 and match candidate selector 206 are coupled to response repository 202 and one or both may use such functions. In some embodiments, there is a “Return all responses” command to which response repository 202 will return all response information it has stored within it. Some other example commands include: “Return all responses associated with user X,” “Return all responses in which user X has responded to another member,” “Return all responses in which another member has responded to user X,” and “Return all responses in which user X has responded to user Y.” In various embodiments, a returned value to a command includes a strength or score of a response, a number of responses (if any), and/or the people associated with a set of response information.
Correlation engine 204 is configured to determine similar users. This is done by accessing information stored in response repository 202 (e.g., for all users as well as for a particular user) and determining similar users in the system for a given user (e.g., a given person being matched or a given match candidate). Any appropriate technique to determine similar users may be used. Some examples include a Pearson correlation, vector similarity, statistical techniques, etc. In some embodiments, correlation engine 204 determines two values for each possible similar user: a similarity value and a confidence value. In some embodiments, if the similarity value is above a first threshold and the confidence value is above a second threshold then a similar user is declared. In some embodiments, similarity values are used to rank users and process through the users from those with highest expected similarity to those with lowest expected similarity.
Based on the similar users determined by correlation engine 204, match candidate selector 206 selects one or more match candidates from a set of available match candidates. In some embodiments, match candidate selector 206 is configured to select a predefined number of matches (e.g., the top 10 match candidates with the highest similarity value and/or highest confidence value). In some embodiments, match candidate selector 206 is configured to select all match candidates above a certain threshold (e.g., with a certain confidence, a certain average response, etc.). In some embodiments, a system predicts how or the degree to which user A is going to respond to user B, how or the degree to which user B is going to respond to user A and then introduces such pairs that are most likely to engage in positive or desired behavior (e.g., mutual communication, achieving a certain stage in a guided communication, go on a date, marry, etc.)
In some embodiments, the set of people associated with the information stored in response repository 202 is not the same as the set of available match candidates from which match candidate selector 206 selects. For example, suppose a former member of a match making service was very active and provided a lot of response information about other users and/or for whom there is a lot of response information from other users. In some cases, it is useful to keep this information in response repository 202 and use this information to make matches, even though that particular person is no longer available as a match candidate (e.g., because (s)he is now in a committed relationship).
In some embodiments, one or more of the components of the system shown in
Based on the known responses (indicated by the unbroken lines), the person being matched (300a) and person 300c have similar responses. Users 300a and 300c both responded positively to users 302a-302b. In some embodiments, identification of user 300c as a user who is similar to 300a is determined by correlation engine 204 of
The person providing the information (i.e., the person shown on the left in
In some cases, a correlation engine identifies multiple users who are similar to a given person. For example, there may be other users who are similar to user 300a (based on the responses they provided) in addition to user 300c. In some embodiments, a weighted average of ratings or responses (e.g., from the multiple users who are identified as being similar) is used. In one example, weights are used. For example, a correlation engine returns a predicted score or weight for each pair of users. A particular set of users may be deemed good enough by having weights above a threshold but (at least in this example) each also has associated with him/her a weight that estimates the degree to which a user will respond positively to that person. This can be used to prioritize users. This is merely one example and in other embodiments other techniques are used.
In some embodiments, user ratings are combined (e.g., using weighting) into a single composite. In one example, users and/or their ratings are weighted proportionally based on their similarity (e.g., Pearson correlation, vector distances, dot products, etc.) to the target user for users who have rated enough users to have a stable estimate. In another example, users are weighted proportionally to a function of their similarity with the active user and the number of items this similarity is based upon (i.e., the most weight would be given to users who have rated a lot of items in a similar way as the target user.)
In some embodiments, the techniques shown in
In some embodiments, the match candidates shown in
In some embodiments, negative reviews or ratings are recorded and correlated. For example, after an in-person meeting, a telephone call, or other form of contact, a person may have the option of indicating they did not like the other person. A negative response may be reflected by a negative value, where a value of 0 corresponds to a neutral response.
In some embodiments, the techniques shown in
At 504, it is determined whether there is sufficient information. For example, correlation engine 204 of
If there is sufficient information, one or more match candidates is/are selected based at least in part on the obtained response information and the collected response information from a plurality of people at 508. Otherwise, at 506, the information is discarded and one or more match candidates is/are selected based on psychographic information. This is merely one example of how to select match candidates if there is insufficient information and in other embodiments some other technique is used at 506 to select match candidates. At 510, information associated with the selected match candidate(s) is presented to the person being matched. For example, the name of the match candidate, contact information, a picture, and/or a description written by the selected match candidate are presented to the person being matched.
In the example shown, there are two distinct modes. There does not need to be a “hard switch” between the two modes and in some embodiments the two predictors are both used by combining their votes.
In some embodiments, matches (e.g., new or additional matches) are delivered at 510 when a user completes communication (e.g., because one of the people chooses not to continue communicating, a communication is interrupted by external elements, etc.). In such cases, the user's utility from receiving such a match is higher than if a match were delivered when the user is engaged in communication with other match(es).
If the piece of information is stale, that piece of information is removed from the repository at 604. After removing the piece of information at 604 or if the piece of information is not stale, it is determined at 606 whether there are more pieces of information. If so, a next piece of information is obtained at 600. In this particular example, data is either included or it is not included. In some embodiments, data is “aged” by weighting older information lower compared to newer information.
In various embodiments, the example process of
In some embodiments, a maintenance process varies from the example shown in
Questionnaire 702 is an example of a questionnaire sent to one or both people who have been matched after they have contacted each other. Some examples of how the people may contact or communicate with each other include a written communication, a telephone call, an in-person meeting, etc. In this particular example, three predefined responses are provided: “Great! I really like him/her,” “Not bad. We'll see how the next time goes,” and “Poorly. I am not interested in him/her.” In various embodiments, other predefined responses are used such as a number or value. In some embodiments, a user can provide a free form response.
At 800, a set of other people with similar responses as a given person being matched is determined. For example, in
At 804, a first set of match candidates with whom the person being matched had a positive response to is determined. For example, in
At 808, the two sets of match candidates are compared. At 810, match candidates who are in both sets are selected.
In this example, 62.5% of the selected match candidates are transparent matches. As used herein, a transparent match is one for which the person being matched is able to see a clear connection or reason as to why a match candidate was selected. For example, the match candidates selected may have one or more demographics (e.g., age, income, education level, income level, etc.) that satisfy a preference specified by the person being matched. In some embodiments, a transparent match is made based on psychographic data (e.g., for the person being matched and/or the match candidates). For example, techniques which use psychographic information may tend to match people with similar personalities together. In some embodiments, some or all of the transparent matches are made using collaborative filtering.
12.5% of the selected match candidates are unexpected matches. As used herein, an unexpected match is one for which the user may not necessarily see a clear reason why a given match candidate is selected. In some embodiments, an unexpected match is made by selecting a match candidate randomly. In some embodiments, an unexpected match is made using collaborative filtering, where (for example) the unexpected match does not necessarily satisfy specified preferences and/or is different compared to previously selected match candidates. One benefit of an unexpected match is to have the person being matched meet and/or consider people whom they might not necessarily consider on their own. Another benefit is that a match making system configured to perform collaborative filtering will be able to obtain response information for a variety of match candidates (e.g., not just for transparent matches).
12.5% of the selected match candidates are new match candidates. A new match candidate someone who has provided relatively little response information about other users and/or for whom relatively few other users have provided response information. Selecting new match candidates may be particularly useful in match making systems that are configured to perform collaborative filtering since decisions are based on response information. In some cases, the decisions (i.e., matches) made by a collaborative filtering match making system tend to improve as more information is obtained and by ensuring new match candidates are being selected, more information generated by or pertaining to these new users can be obtained.
The remaining 12.5% of the selected matches are trust-generating matches. A trust-generating match is one in which the system has a high confidence, for example because those particular match candidates have been rated many times and have consistently high responses by other users. In some embodiments, an average rating or response value is used.
Although a system may select a particular percentage of match candidates using a particular technique as shown in this figure, a match making system does not necessarily indicate to a user which selected match candidates fall into which category. In some cases indicating which person was selecting using which technique causes a user to be predisposed.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
Number | Name | Date | Kind |
---|---|---|---|
6266649 | Linden et al. | Jul 2001 | B1 |
7203674 | Cohen | Apr 2007 | B2 |
7428321 | Shah et al. | Sep 2008 | B1 |
7450740 | Shah et al. | Nov 2008 | B2 |
7617160 | Grove et al. | Nov 2009 | B1 |
7885902 | Shoemaker et al. | Feb 2011 | B1 |
20020040310 | Lieben et al. | Apr 2002 | A1 |
20030078976 | Gordon | Apr 2003 | A1 |
20030191673 | Cohen | Oct 2003 | A1 |
20060018522 | Sunzeri et al. | Jan 2006 | A1 |
20060059159 | Truong et al. | Mar 2006 | A1 |
20060242053 | Avital | Oct 2006 | A1 |
20070192106 | Zilca | Aug 2007 | A1 |
20080052312 | Tang et al. | Feb 2008 | A1 |
20080162157 | Daniluk | Jul 2008 | A1 |
20080279419 | Kluesing et al. | Nov 2008 | A1 |
20080317298 | Shah et al. | Dec 2008 | A1 |
20090060288 | Myers et al. | Mar 2009 | A1 |
20090060289 | Shah et al. | Mar 2009 | A1 |
20090070133 | Bonilla et al. | Mar 2009 | A1 |
20090116704 | Shah et al. | May 2009 | A1 |
20090319288 | Slaney et al. | Dec 2009 | A1 |
20100262611 | Frind | Oct 2010 | A1 |