A proximity search engine for carrying out a proximity search with respect to a reference location uses as a reference frame the earth divided into tiles, which are predefined geographic regions of substantially equal areas. Records that are searched based on proximity to a reference location include location pointers, each of which identifies a particular tile that encompasses the physical location indicated by the corresponding record. When the proximity search is carried out, the tiles that are within a specified distance from the reference location are obtained and records having location pointers corresponding to such tiles are selected for inclusion in the search results.

Patent
   RE44876
Priority
Sep 14 2004
Filed
Oct 19 2011
Issued
Apr 29 2014
Expiry
Sep 14 2024
Assg.orig
Entity
Large
0
84
all paid
8. A record management system for performing searches based on proximity to a reference location, comprising:
a memory device containing a plurality of searchable records, each searchable record including a location pointer that corresponds to one of a plurality of predefined geographic regions, each of the predefined geographic regions having four sides of an equal surface distance and associated with a location pointer having a first index and a second index, the first index and the second index identifying a point on a coordinate system; and
a processor programmed to: (i) receive a search query including the reference location and a distance value; (ii) generate a reference location pointer having a first index and a second index for the reference location; (iii) divide the distance value by the equal surface distance to obtain an integer number, N; (iv) identify a set of location pointers having a first index that differs from the first index of the reference location pointer by no more than N and a second index that differs from a third index by no more than N, wherein the third index is a function of the first index of the reference location pointer and represents the same longitudinal position as the reference location pointer; and (v) return records having location pointers in the identified set.
1. A method carried out by a computer system of identifying records based on proximity to a reference location in response to a search query, comprising the steps of:
by one or more computing devices, determining location data representative of the reference location; converting said location data into a reference location pointer that points to one of a plurality of predefined geographic regions, each of the predefined geographic regions having four sides of an equal surface distance and associated with a location pointer having a first index and a second index, the first index and the second index identifying a point on a coordinate system;
by the one or more computing devices, identifying a set of location pointers whose corresponding predefined geographic regions are within a certain distance from the predefined geographic region corresponding to the reference location pointer using an integer number, N, which is obtained by dividing the certain distance by the equal surface distance, wherein each of the location pointers in the set has a first index that differs from the first index of the reference location pointer by no more than N and a second index that differs from a third index by no more than N, wherein the third index is a function of the first index of the reference location pointer and represents the same longitudinal position as the reference location pointer; and
by the one or more computing devices, identifying records having location pointers that are in the set.
0. 26. One or more computer-readable non-transitory storage media embodying software operable when executed by one or more computer systems to:
receive a query from a first user of a social-networking system, the social-networking system comprising a graph that comprises a plurality of nodes and edges connecting the nodes, at least one node in the graph corresponding to the first user, the query comprising one or more location data corresponding to a location of the first user;
identify one or more second users of the social-networking system that are connected to the first user within the social-networking system, at least one node in the graph corresponding to each of the second users, at least one of the nodes corresponding to the first user and at least one of the nodes corresponding to a second user being connected to each other by one or more edges;
determine a location of each of one or more of the second users;
identify one or more of the second users that are located within a threshold distance of the location of the first user, wherein, to identify one or more of the second users that are located within a threshold distance of the location of the first users, the software is further operable when executed to:
convert location information associated with each of at least one of the nodes corresponding to the second users to a location pointer that points to one of a plurality of predefined geographic regions, each of the plurality of predefined geographic regions having four sides of an equal surface distance and is associated with a location pointer having a first index and a second index, the first index and the second index identifying a point on a coordinate system;
convert the one or more location data into a reference location pointer that points to one of the plurality of predefined geographic regions; and
identify a set of location pointers whose corresponding predefined geographic regions are within the distance from the predefined geographic region corresponding to the reference location pointer using an integer number, N, which is obtained by dividing the distance by the equal surface distance, wherein each location pointer from the set of location pointers has a first index that differs from the first index of the reference location pointer by no more than N and a second index that differs from a third index by no more than N, wherein the third index is a function of the first index of the reference location pointer and represents the same longitudinal position as the reference location pointer; and
provide as a response to the query information associated with each of one or more of the second users that are located within the threshold distance of the location of the first user.
0. 12. A method comprising:
by one or more computing devices, receiving a query from a first user of a social-networking system, the social-networking system comprising a graph that comprises a plurality of nodes and edges connecting the nodes, at least one node in the graph corresponding to the first user, the query comprising one or more location data corresponding to a location of the first user;
by the computing devices, identifying one or more second users of the social-networking system that are connected to the first user within the social-networking system, at least one node in the graph corresponding to each of the second users, at least one of the nodes corresponding to the first user and at least one of the nodes corresponding to a second user being connected to each other by one or more edges;
by the computing devices, determining a location of each of one or more of the second users;
by the computing devices, identifying one or more of the second users that are located within a threshold distance of the location of the first user, wherein identifying one or more of the second users that are located within a threshold distance of the location of the first users comprises:
by the computing devices, converting location information associated with each of at least one of the nodes corresponding to the second users to a location pointer that points to one of a plurality of predefined geographic regions, each of the plurality of predefined geographic regions having four sides of an equal surface distance and is associated with a location pointer having a first index and a second index, the first index and the second index identifying a point on a coordinate system;
by the computing devices, converting the one or more location data into a reference location pointer that points to one of the plurality of predefined geographic regions; and
by the computing devices, identifying a set of location pointers whose corresponding predefined geographic regions are within the distance from the predefined geographic region corresponding to the reference location pointer using an integer number, N, which is obtained by dividing the distance by the equal surface distance, wherein each location pointer from the set of location pointers has a first index that differs from the first index of the reference location pointer by no more than N and a second index that differs from a third index by no more than N, wherein the third index is a function of the first index of the reference location pointer and represents the same longitudinal position as the reference location pointer; and
by the computing devices, providing, as a response to the query, information associated with each of one or more of the second users that are located within the threshold distance of the location of the first user.
0. 19. A system comprising:
a memory comprising instructions executable by one or more processors; and
the processors coupled to the memory and operable to execute the instructions, the one or more processors being operable when executing the instructions to:
receive a query from a first user of a social-networking system, the social-networking system comprising a graph that comprises a plurality of nodes and edges connecting the nodes, at least one node in the graph corresponding to the first user, the query comprising one or more location data corresponding to a location of the first user;
identify one or more second users of the social-networking system that are connected to the first user within the social-networking system, at least one node in the graph corresponding to each of the second users, at least one of the nodes corresponding to the first user and at least one of the nodes corresponding to a second user being connected to each other by one or more edges;
determine a location of each of one or more of the second users;
identify one or more of the second users that are located within a threshold distance of the location of the first user, wherein to identify one or more of the second users that are located within a threshold distance of the location of the first users, the one or more processors are operable when executing the instructions to:
convert location information associated with each of at least one of the nodes corresponding to the second users to a location pointer that points to one of a plurality of predefined geographic regions, each of the plurality of predefined geographic regions having four sides of an equal surface distance and is associated with a location pointer having a first index and a second index, the first index and the second index identifying a point on a coordinate system;
convert the one or more location data into a reference location pointer that points to one of the plurality of predefined geographic regions; and
identify a set of location pointers whose corresponding predefined geographic regions are within the distance from the predefined geographic region corresponding to the reference location pointer using an integer number, N, which is obtained by dividing the distance by the equal surface distance, wherein each location pointer from the set of location pointers has a first index that differs from the first index of the reference location pointer by no more than N and a second index that differs from a third index by no more than N, wherein the third index is a function of the first index of the reference location pointer and represents the same longitudinal position as the reference location pointer; and
provide as a response to the query information associated with each of one or more of the second users that are located within the threshold distance of the location of the first user.
2. The method according to claim 1, wherein the search query specifies the certain distance.
3. The method according to claim 2, wherein the reference location is the location from which the search query is received.
4. The method according to claim 2, wherein the reference location is the location specified in a record corresponding to the user who submitted the search query.
5. The method according to claim 1, further comprising the step of maintaining a plurality of records in a database, each of the plurality of records including a location pointer to one of the plurality of predefined geographic regions.
6. The method according to claim 5, wherein the predefined geographic regions corresponding to the set of location pointers comprises a subset of the plurality of predefined geographic regions.
7. The method according to claim 1, wherein said location data comprises latitude and longitude values.
9. The system according to claim 8, wherein the processor is further programmed to: (i) receive an input of a searchable record including location information associated with the searchable record; (ii) convert the location information into a location pointer that corresponds to one of the plurality of predefined geographic regions; and (iii) store the location pointer.
10. The system according to claim 9, wherein the location information comprises a zip code.
11. The system according to claim 9, wherein the location information includes city and country.
0. 13. The method of claim 12, further comprising sending the response to the first user.
0. 14. The method of claim 12, wherein the query comprises the threshold distance.
0. 15. The method of claim 12, wherein:
the query comprises one or more keywords;
each of one or more nodes in the graph corresponding to each of one or more second users is associated with one or more keywords;
the method further comprises, by the computing devices, identifying among the second users that are located within the threshold distance of the location of the first user one or more second users that correspond to nodes associated with keywords matching the keywords of the query; and
information associated with a second user is provided as a response to the query only if the node corresponding to the second is associated with keywords matching the keywords in the query.
0. 16. The method of claim 12, wherein:
the query comprises a gender;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a gender of the second user;
the method further comprises, by the computing devices, identifying among the second users that are located within the threshold distance of the location of the first user one or more second users that match the gender in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the gender in the query.
0. 17. The method of claim 12, wherein:
the query comprises a marital status;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a marital status of the second user;
the method further comprises, by the computing devices, identifying among the second users that are located within the threshold distance of the location of the first user one or more second users that match the marital status in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the marital status in the query.
0. 18. The method of claim 12 wherein identifying one or more of the second users that are located within a threshold distance of the location of the first users comprises:
mapping location information associated with each of at least one of the nodes corresponding to the second users to one of a plurality of geographic regions; and
mapping the location data to a first geographic region of the plurality of geographic regions.
0. 20. The system of claim 19, wherein the processors are further operable when executing the instructions to send the response to the first user.
0. 21. The system of claim 19, wherein the query comprises the threshold distance.
0. 22. The system of claim 19, wherein:
the query comprises one or more keywords;
each of one or more nodes in the graph corresponding to each of one or more second users is associated with one or more keywords;
the processors are further operable when executing the instructions to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that correspond to nodes associated with keywords matching the keywords of the query; and
information associated with a second user is provided as a response to the query only if the node corresponding to the second is associated with keywords matching the keywords in the query.
0. 23. The system of claim 19, wherein:
the query comprises a gender;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a gender of the second user;
the processors are further operable when executing the instructions to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that match the gender in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the gender in the query.
0. 24. The system of claim 19, wherein:
the query comprises a marital status;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a marital status of the second user;
the processors are further operable when executing the instructions to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that match the marital status in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the marital status in the query.
0. 25. The system of claim 19, wherein, to identify one or more of the second users that are located within a threshold distance of the location of the first users, the processors are operable when executing the instructions to:
map location information associated with each of at least one of the nodes corresponding to the second users to one of a plurality of geographic regions; and
map the location data to a first geographic region of the plurality of geographic regions.
0. 27. The media of claim 26, wherein the software is further operable when executed to send the response to the first user.
0. 28. The media of claim 26, wherein the query comprises the threshold distance.
0. 29. The media of claim 26, wherein:
each of one or more nodes in the graph corresponding to each of one or more second users is associated with one or more keywords;
the software is further operable when executed to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that correspond to nodes associated with keywords matching the keywords of the query; and
information associated with a second user is provided as a response to the query only if the node corresponding to the second is associated with keywords matching the keywords in the query.
0. 30. The media of claim 26, wherein:
the query comprises a gender;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a gender of the second user;
the software is further operable when executed to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that match the gender in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the gender in the query.
0. 31. The media of claim 26, wherein:
the query comprises a marital status;
each of one or more nodes in the graph corresponding to each of one or more second users indicates a marital status of the second user;
the software is further operable when executed to identify among the second users that are located within the threshold distance of the location of the first user one or more second users that match the marital status in the query; and
information associated with a second user is provided as a response to the query only if the second user matches the marital status in the query.
0. 32. The media of claim 26, wherein, to identify one or more of the second users that are located within a threshold distance of the location of the first users, the software is further operable when executed to:
map location information associated with each of at least one of the nodes corresponding to the second users to one of a plurality of geographic regions; and
map the location data to a first geographic region of the plurality of geographic regions.

1. Field of the Invention

The present invention generally relates to proximity search techniques, and more specifically, to a method and a system for performing searches based on proximity to a reference location.

2. Description of the Related Art

A geographic location may be represented as latitude and longitude. FIG. 1 illustrates a map of the world with latitude lines shown every 30 degrees and longitude lines shown every 30 degrees. The distance between any two points on the map shown in FIG. 1 may be calculated based on their latitude and longitude positions, and the known radius of the earth (6371.01 km or 3958.76 miles).

There are many ways of obtaining the latitude and longitude for a particular geographic location. Latitude and longitude positions for locations specified using zip codes, postal codes and cities may be obtained from third party databases using a simple table look-up. Also, a handheld electronic device, such as a pocket PC, cell phone or a personal digital assistant (PDA), may have a GPS receiver and associated software for determining the latitude and longitude position of the handheld electronic device.

In the current art, a proximity search of database records with respect to a reference location is carried out by calculating the distances between the reference location and the locations associated with each of the database records. First, the latitude and longitude positions of the reference location are obtained. Second, the latitude and longitude positions of the locations associated with the database records are obtained. Third, the distances between the reference location and the locations associated with the database records are calculated. Fourth, the database records associated with locations that are within a certain distance (as specified in the proximity search request) from the reference location are selected to be included in the search results.

When the number of database records is large, the proximity search method carried out in the above manner becomes computationally very expensive because of the large number of distance calculations that are required. Distance calculations that are based on zip codes and postal codes have been used to reduce the computational cost, but are not very accurate, and only work for locations in countries having postal codes that are mapped to latitude-longitude values. Quad trees and R-Trees that rely on a two-dimensional grid of regions and subregions have been used to describe the locations of objects in a two-dimensional space, but they require binary-like searches to zero in on the appropriate regions. For proximity searching, they are either too inaccurate (e.g., when the region size is large) or computationally too expensive (e.g., when the region size is sufficiently small).

The invention provides an improved proximity search technique that is either faster or more accurate than the ones employed in the current art. According to the invention, the earth is divided into predefined geographic regions of substantially equal areas, referred to as tiles, and records that are searched based on proximity to a reference location include location pointers, each of which identifies a particular tile that encompasses the physical location indicated by the corresponding record. When the proximity search is carried out, the tiles that are within a specified distance from the reference location are obtained and records having location pointers corresponding to such tiles are selected for inclusion in the search results.

The reference location may be specified in the proximity search as a zip code, city-state, or city-country, or the location of the user requesting the proximity search may be retrieved from a database as the reference location. If the user requesting the proximity search is carrying a handheld electronic device that includes a GPS receiver and associated software, the reference location may also be specified as the current location of the user as determined by the GPS receiver and associated software.

After the reference location is determined, the latitude and longitude of the reference location are obtained and the tile that includes the latitude and longitude of the reference location is identified. The searched records that have location pointers that point to those tiles that are within the specified distance from the reference location tile are then selected for inclusion in the search results.

Proximity searches carried out in the above manner no longer require individual distance calculations between the reference location and each database record being searched. As a result, the total number of distance calculations is reduced with the invention and the speed of the executed searches is increased. The invention also provides flexibility in designing proximity searches, e.g., the accuracy of proximity searches can be increased by decreasing the tile size and the speed of the proximity searches can be increased by increasing the tile size.

So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.

FIG. 1 is a map of the world illustrating latitude and longitude lines that uniquely identify a location on the map;

FIG. 2 is a map of the world employing a coordinate system defining points that represent geographic regions having substantially the same area;

FIG. 3 is a diagram illustrating the relationships between members in a social network:

FIG. 4 is a block diagram illustrating a system for creating and managing an online social network;

FIG. 5 shows a simplified user interface with which a new record is entered into a database;

FIG. 6 is a flow diagram illustrating how a location pointer is obtained for the new record entered in FIG. 5;

FIG. 7 illustrates a database containing records having location information;

FIG. 8 shows an input interface for specifying a search query that includes a proximity criteria; and

FIG. 9 is a flow diagram illustrating how search results that are responsive to the search query of FIG. 8 are obtained.

Each geographic location in FIG. 1, which can be represented as latitude and longitude, may be mapped onto a point in FIG. 2. In fact, the map of FIG. 1 is divided into a plurality predefined geographical regions or areas, referred to as tiles, and all points contained in one tile map onto a single point in FIG. 2. A tile can have any configuration, but in the embodiment of the invention described herein, each such tile covers roughly the same area in FIG. 1 and all four sides of each such tile have the same fixed length. The formulas used for mapping a location in FIG. 1 that is defined by latitude and longitude onto a point in FIG. 2 are as follows:
LatQ=Int((latitude+90)*k/r+1); and
LongQ=Int((longitude+180)*k Cos (latitude/r+1),
where latitude and longitude values are expressed in degrees; k is a factor for converting a 1-degree arc measured with respect to earth's center into miles (k=2π*(earth's radius)/360°-69.0933 miles/degree); r is the length of each side of a tile (in the illustrated embodiment, r=3.4 miles); and LatQ and LongQ define the position of a tile in the coordinate system shown in FIG. 2.

The LatQ value defines the position of the tile along the x-axis, beginning with LatQ=1, and the LongQ value defines the position of the tile along the y-axis, beginning with LongQ=1. The north pole in FIG. 1 is mapped onto a point at the upper tip of the triangle in FIG. 2 represented by (LatQ=3658, LongQ=1) and the south pole in FIG. 1 is mapped onto a point at the lower tip of the triangle in FIG. 2 represented by (LatQ−1, LongQ−1). The equator, represented by (LatQ=1829, 1<LongQ<7316), maps onto a line that cuts through the center of the triangle in FIG. 2 and divides it into an upper half (northern hemisphere) and a lower half (southern hemisphere). The right tip of the triangle in FIG. 2 represents the (LatQ, LongQ) pair corresponding to the tile that contains the equator at the international date line (longitude: 180° E or 180° W).

The international date line maps onto a line that is shown in FIG. 2 as the left side of the triangle. All other equilongitude lines (i.e., a line connecting points having the same longitude) map onto a pair of lines, the first originating from the north pole (LatQ=3658, LongQ=1) to a point along the equator and the second originating from the south pole (LatQ=1, LongQ=1) to the same point along the equator. The upper and lower sides of the triangle in FIG. 2 represent the international date line that is approached when moving west to east.

The invention will now be described in the context of a social network. A social network is generally defined by the relationships among groups of individuals, and may include relationships ranging from casual acquaintances to close familial bonds. A social network may be represented using a graph structure. Each node of the graph corresponds to a member of the social network. Edges connecting two nodes represent a relationship between two individuals. In addition, the degree of separation between any two nodes is defined as the minimum number of hops required to traverse the graph from one node to the other. A degree of separation between two members is a measure of relatedness between the two members.

FIG. 3 illustrates a graph representation of a social network centered on a given individual (ME). Other members of this social network include A-U whose position, relative to ME's, is referred to by the degree of separation between ME and each other member. Friends of ME, which includes A, B, and C, are separated from ME by one degree of separation (1 d/s). A friend of a friend of ME is separated from ME by 2 d/s. As shown, D, E, F and G are each separated from ME by 2 d/s. A friend of a friend of a friend of ME is separated from ME by 3 d/s. FIG. 1 depicts all nodes separated from ME by more than 3 degrees of separation as belonging to the category ALL.

Degrees of separation in a social network are defined relative to an individual. For example, in ME's social network, H and ME are separated by 2 d/s, whereas in G's social network. H and G are separated by only 1 d/s. Accordingly, each individual will have their own set of first, second and third degree relationships.

As those skilled in the art understand, an individual's social network may be extended to include nodes to an Nth degree of separation. As the number of degrees increases beyond three, however, the number of nodes typically grows at an explosive rate and quickly begins to mirror the ALL set.

FIG. 4 is a block diagram illustrating a system for creating and managing an online social network. As shown, FIG. 4 illustrates a system 100, including an application server 200 and graph servers 300. The computers of system 100 are connected by a network 400, e.g., the Internet, and accessible by over the network by a plurality of computers, collectively designated as 500. The application server 200 manages a member database 210, a relationship database 220, and a search database 230.

The member database 210 contains profile information for each of the members in the online social network managed by the system 100. The profile information may include, among other things: a unique member identifier, name, age, gender, location, hometown, references to image files, listing of interests, attributes, and the like. The location information may include: (i) address, city, state, zip code or postal code, and country; (ii) latitude and longitude values associated with the specified address, zip code, postal code, city-state or city-country; and (iii) a pointer to a tile that includes the location associated with the latitude and longitude values. The relationship database 220 stores information defining to the first degree relationships between members. The relationship database 220 stores information relating to the first degree relationships between members. In addition, the contents of the member database 210 are indexed and optimized for search, and stored in the search database 230. The member database 210, the relationship database 220, and the search database 230 are updated to reflect inputs of new member information and edits of existing member information that are made through the computers 500.

The application server 200 also manages the information exchange requests that it receives from the remote computers 500. The graph servers 300 receive a query from the application server 200, process the query and return the query results to the application server 200. Graph servers 300 store a graph representation of the social network defined by all of the members (nodes) and their corresponding relationships (edges). The graph servers 300 respond to requests from application server 200 to identify relationships and the degree of separation between members of the online social network.

The application server 200 is further configured to query a third party service 600 for latitude and longitude values corresponding to location information (e.g., address, zip code, postal code, city-state, city-country, etc.) that it sends as a part of the query. The third party service 600 looks up the latitude and longitude values corresponding to the location specified in the query from its database 610 and returns the latitude and longitude values to the application server 200. In an alternative embodiment, the database containing latitude and longitude values corresponding to locations specified in terms of address, zip code, postal code, city-state, and/or city-country, may be maintained as part of the computer system 100 and accessed internally by the application server 200.

FIG. 5 shows a simplified user interface with which a new record is entered into the member database 210. The inputs include location information such as the address, city, state and zip code. Persons not living in the U.S. will enter country information in place of state and postal code information instead of zip code.

FIG. 6 is a flow diagram illustrating how a location pointer is obtained for a new record and stored in the member database 210. In Step 601, user inputs, e.g., those made with the user interface of FIG. 5, are received by the computer system 100 and stored in the member database 210. In Step 602, the computer system 100 queries a third party service 600 for latitude and longitude values corresponding to the location information associated with the new record and receives them from the third party service 600. The location parameters that are passed to the third party service 600 may be address, city, state, country, zip code, postal code, or any combination of the foregoing. The third party service 600 looks up the latitude and longitude values corresponding to the location parameters and returns them to the computer system 100. In an alternative embodiment, the latitude and longitude look up is not performed by the third party service 600, but by the computer system 100.

In Step 603, the latitude and longitude values are used to calculate corresponding LatQ and LongQ values using the following formula:
LatQ=Int((latitude+90)*k/r+1); and
LongQ=Int((longitude+180)*k* Cos (latitude)/r+1).
where k is a factor for converting a 1-degree arc measured with respect to earth's center into miles (k=2π*(earth's radius)/360°=69.0933 miles/degree); r is the length of the sides of the tiles and is 3.4 miles; and latitude and longitude values are expressed in degrees. Accuracy in the proximity searches can be improved by reducing r, but at the expense of computational speed. Computation speed of the proximity searches can be increased by increasing r, but at the expense of accuracy.

In Step 604, the (LatQ, LongQ) pair is stored in the member database 210 as part of the new record and is used as a pointer to identify the particular tile that covers the location associated with the new record. To optimize for database indexing, the (LatQ, LongQ) pair may be packed into a single integer value.

FIG. 7 illustrates a member database 210 containing location information. It shows the location information for records ME, A, B, C, and U, and the corresponding latitude and longitude values. Each record also has a pointer (x, y) that identifies the particular tile that covers the location associated with such record. Each of these pointers was derived in the manner illustrated in FIG. 6 when its corresponding record was entered into the database as a new record. For example, the record ME has a zip code 94087 which, according to a latitude and longitude look-up service, is located at 37.40 N latitude and 122.00 W longitude, and this location maps onto a tile that is located at point (x=2589, y=937).

FIG. 8 shows a sample input interface for specifying a search query that includes a proximity criterion. The input parameter “Your Location” defaults to the zip code of the person who is requesting this search, but it may be changed by the user if the user desires to perform the proximity search with respect to a different zip code. If the search query is being entered using a handheld electronic device that includes a GPS receiver and associated software that automatically determines the latitude and longitude values associated with the current location of the handheld electronic device, and the user desires to perform the proximity search based on the GPS-determined location, the user leaves the “Your Location” field blank, and the latitude and longitude values determined by the GPS receiver and associated software appears in the corresponding “Latitude” and “Longitude” fields and are passed as part of the search query. The location specified in the “Your Location” field or the GPS-determined location represents the reference location from which the proximity search will be carried out.

The input parameter “Proximity” defines the distance value that is used in carrying out the proximity search. A distance value of 25 miles, as illustrated in FIG. 8, means that the proximity search will be carried out for all records having associated locations that are within 25 miles of the reference location. Other input parameters may be specified in conducting a proximity search (e.g., keywords, gender preference, marital status, etc.), but for simplicity, are not illustrated here. Also, the invention is applicable to any type of proximity searches, and not limited to proximity searches for members within a social network.

FIG. 9 is a flow diagram illustrating how search results that are responsive to the search query are obtained. In Step 901, the proximity search parameters, e.g., those made with the user interface of FIG. 8, are received by the computer system 100. In Step 902, a decision is made as to whether latitude and longitude values are passed as part of the search query. If not, the reference location information, e.g., zip code, is passed to the third party service 600, and the third party service 600 looks up the latitude and longitude values corresponding to the reference location information and returns them to the computer system 100 (Step 903). In an alternative embodiment, the latitude and longitude look up is not performed by the third party service 600, but by the computer system 100. Flow then proceeds to Step 904.

If the latitude and longitude values are passed as part of the search query, Step 903 is skipped and flow proceeds directly to Step 904. In Step 904, a set of (LatQ, LongQ) values that correspond to the longitude of the reference location and are within the specified distance from the reference location is obtained. In Step 905, for each (LatQ, LongQ) value in the set obtained in Step 904, all LongQ values that are within the specified distance directly to the west and directly to the east (i.e., to the west and to the east along the same latitude) are obtained. In Step 906, all (LatQ, LongQ) values obtained in Step 905 are compiled into an array as valid location pointers. In Step 907, if any records in the database have (LatQ, LongQ) values that are contained in the array of valid location pointers, these records are included in the search results.

The code that implements Steps 904-906 of FIG. 9 is reproduced below:

Round represents an integer operation of rounding up
for (i = −Range; i <= Range; i++) {
midBoxLat = latitude + i * r / k; // latitude is the latitude of
the reference location; k is the factor for converting 1 degree of
latitude into miles and equals 69.0933 miles/degree
midBoxLatQ = Int((midBoxLat + 90)*k/r+1);
midBoxLonQ = Int((longitude+180)*k*Cos(midBoxLat)/r+1); //
longitude is the longitude of the reference location
for (j = midBoxLonQ − Range; j <= midBoxLonQ +Range; j++) {
list.add((midBoxLatQ | j);
}
}

While particular embodiments according to the invention have been illustrated and described above, those skilled in the art understand that the invention can take a variety of forms and embodiments within the scope of the appended claims.

Galbreath, Nicholas, Soung, Yuh-Wen

Patent Priority Assignee Title
Patent Priority Assignee Title
5839088, Aug 22 1996 WGRS LICENSING COMPANY, LLC Geographic location referencing system and method
5848373, Jun 24 1994 Garmin Switzerland GmbH Computer aided map location system
5950200, Jan 24 1997 SPARK NETWORKS USA, LLC Method and apparatus for detection of reciprocal interests or feelings and subsequent notification
5956397, Feb 22 1993 NEUSTAR INFORMATION SERVICES, INC Automatic routing and information system for telephonic services
5963951, Jun 30 1997 HANGER SOLUTIONS, LLC Computerized on-line dating service for searching and matching people
5968109, Oct 25 1996 HERE GLOBAL B V System and method for use and storage of geographic data on physical media
5974419, Oct 25 1996 HERE GLOBAL B V Parcelization of geographic data for storage and use in a navigation application
5978768, May 08 1997 CAREERBUILDER, INC Computerized job search system and method for posting and searching job openings via a computer network
6014090, Dec 22 1997 GOOGLE LLC Method and apparatus for delivering local information to travelers
6047236, Aug 22 1996 WGRS LICENSING COMPANY, LLC Geographic location referencing system and method
6052122, Jun 13 1997 TELE-PUBLISHING, INC Method and apparatus for matching registered profiles
6061681, Jun 30 1997 HANGER SOLUTIONS, LLC On-line dating service for locating and matching people based on user-selected search criteria
6073105, Jun 13 1997 TELE-PUBLISHING, INC Interactive personals online network method and apparatus
6073138, Jun 11 1998 TRADECO ASIA LTD System, method, and computer program product for providing relational patterns between entities
6175831, Jan 17 1997 DEGREES OF CONNECTION LLC Method and apparatus for constructing a networking database and system
6202023, Aug 22 1996 WGRS LICENSING COMPANY, LLC Internet based geographic location referencing system and method
6223122, Aug 22 1996 WGRS LICENSING COMPANY, LLC Geographic location referencing system and method
6249282, Jun 13 1997 Tele-Publishing, Inc. Method and apparatus for matching registered profiles
6266612, Oct 24 1996 Trimble Navigation Limited Position based personal digital assistant
6269369, Nov 02 1997 AMAZON COM HOLDINGS, INC Networked personal contact manager
6324541, Jun 11 1998 TRADECO ASIA LTD System, method, and computer program product for providing relational patterns between entities
6326918, Jun 06 1995 Wayport, Inc. Method and apparatus for geographic-based communications service
6339397, Jun 01 2000 GEOTAB Inc Portable self-contained tracking unit and GPS tracking system
6339744, Aug 22 1996 PROCEPTS, LLC Geographic location referencing system and method
6343274, Sep 11 1998 Qualcomm Incorporated Apparatus and method for merchant-to-consumer advertisement communication system
6343317, Dec 29 1999 CRYSTAL MOUNTAIN COMMUNICATIONS, LLC Internet system for connecting client-travelers with geographically-associated data
6347230, Jul 25 1995 Ace K Computer Co., Ltd. Position display system of mobile terminal
6349257, Sep 15 1999 International Business Machines Corporation System for personalized mobile navigation information
6349290, Jun 30 1998 CITIBANK, N A Automated system and method for customized and personalized presentation of products and services of a financial institution
6353785, Mar 12 1999 HERE GLOBAL B V Method and system for an in-vehicle computer architecture
6356812, Sep 14 2000 GOOGLE LLC Method and apparatus for displaying information in a vehicle
6356838, Jul 25 2000 SC INNOVATIONS, INC System and method for determining an efficient transportation route
6360167, Jan 29 1999 BEACON NAVIGATION GMBH Vehicle navigation system with location-based multi-media annotation
6363427, Dec 18 1998 INTELL CORPORATION Method and apparatus for a bulletin board system
6366962, Dec 18 1998 Intel Corporation Method and apparatus for a buddy list
6370510, May 08 1997 WILMINGTON TRUST, NATIONAL ASSOCIATION, AS SUCCESSOR AGENT AND AS ASSIGNEE Employment recruiting system and method using a computer network for posting job openings and which provides for automatic periodic searching of the posted job openings
6370513, Aug 08 1997 DIETFOOD CORP Method and apparatus for automated selection, organization, and recommendation of items
6370566, Apr 10 1998 Microsoft Technology Licensing, LLC Generating meeting requests and group scheduling from a mobile device
6374177, Sep 20 2000 Google Technology Holdings LLC Method and apparatus for providing navigational services in a wireless communication device
6381603, Feb 22 1999 KNAPP INVESTMENT COMPANY LIMITED System and method for accessing local information by using referencing position system
6401039, Feb 10 1997 Baron Services, Inc. System and method for projecting storms using NEXRAD attributes
6408309, Feb 23 2000 VS TECHNOLOGIES, LLC Method and system for creating an interactive virtual community of famous people
6505121, Aug 01 2001 HTC Corporation Onboard vehicle navigation system
6542748, Jun 10 2000 GOOGLE LLC Method and system for automatically initiating a telecommunications connection based on distance
6618593, Sep 08 2000 WESERVE SYNVEST, LLC Location dependent user matching system
6701307, Oct 28 1998 Microsoft Technology Licensing, LLC Method and apparatus of expanding web searching capabilities
6735568, Aug 10 2000 EHARMONY, INC Method and system for identifying people who are likely to have a successful relationship
6741188, Oct 22 1999 CORRINO HOLDINGS LLC System for dynamically pushing information to a user utilizing global positioning system
6906643, Apr 30 2003 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Systems and methods of viewing, modifying, and interacting with “path-enhanced” multimedia
7010308, Dec 13 2000 CORTLAND CAPITAL MARKET SERVICES LLC, AS ADMINISTRATIVE AGENT Managing and querying moving point data
7071842, Jun 27 2002 Intellectual Ventures II LLC System and method for locating and notifying a user of a person, place or thing having attributes matching the user's stated preferences
7072963, Apr 03 2000 DEUTSCHE BANK AG NEW YORK BRANCH Method and system to modify geolocation activities based on logged query information
7876215, Jun 27 2002 Intellectual Ventures II LLC System and method for locating and notifying a mobile user of people having attributes or interests matching a stated preference
8102253, Jun 27 2002 Intellectual Ventures II LLC System and method for notifying a user of people, places or things having attributes matching a user's stated preference
20020051540,
20020054082,
20020086676,
20020106066,
20020123934,
20020151315,
20030063072,
20030069693,
20030074471,
20030154194,
20040034601,
20040064334,
20040066330,
20040068582,
20040076279,
20040077359,
20040078489,
20040104842,
20040110515,
20040117358,
20040139049,
20040144301,
20040148275,
20040198398,
20040266457,
20050003831,
20050015307,
20060200492,
20070005373,
20080133716,
//
Executed onAssignorAssigneeConveyanceFrameReelDoc
Oct 19 2011Facebook, Inc.(assignment on the face of the patent)
Oct 28 2021Facebook, IncMeta Platforms, IncCHANGE OF NAME SEE DOCUMENT FOR DETAILS 0585530802 pdf
Date Maintenance Fee Events
Apr 06 2017M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Mar 24 2021M1553: Payment of Maintenance Fee, 12th Year, Large Entity.


Date Maintenance Schedule
Apr 29 20174 years fee payment window open
Oct 29 20176 months grace period start (w surcharge)
Apr 29 2018patent expiry (for year 4)
Apr 29 20202 years to revive unintentionally abandoned end. (for year 4)
Apr 29 20218 years fee payment window open
Oct 29 20216 months grace period start (w surcharge)
Apr 29 2022patent expiry (for year 8)
Apr 29 20242 years to revive unintentionally abandoned end. (for year 8)
Apr 29 202512 years fee payment window open
Oct 29 20256 months grace period start (w surcharge)
Apr 29 2026patent expiry (for year 12)
Apr 29 20282 years to revive unintentionally abandoned end. (for year 12)