Techniques for searching and providing geographical regions are described. The process searches and recommends points of interests based on a user-specified region. points of interests include spatial objects (e.g., buildings, landmarks, rivers, parks) and their distributions in a geographical region. The process searches and recommends points of interests by partitioning a spatial map into grids to identify representative categories located in each of the grids. In response to the user-specified region, a set of geographical candidates containing the representative categories is retrieved. The process determines whether the user-specified region and the set of geographical candidates include similar or common representative categories and similar or common spatial distributions of the representative categories. Then the process provides the top ranked set of geographical candidates that have similar content information.
|
1. A method implemented at least partially by one or more processors, the method comprising:
providing a spatial map containing geographical regions partitioned into grids;
identifying a user-specified region with a first plurality of points of interests in each of one or more representative categories in the spatial map;
searching for a set of geographical region candidates with a second plurality of points of interests in each of the one or more representative categories based at least in part on a spatial similarity to comparable points of interest in the one or more representative categories in the user-specified region, the spatial similarity comprises comparable distribution of respective points of interests of the user-specified region and the set of geographical region candidates in the one or more representative categories; and
presenting a predefined number of top geographical region candidates of the set of geographical region candidates based at least in part on a result of the searching.
10. A system comprising:
a memory;
one or more processors coupled to the memory to perform acts comprising:
providing a spatial map containing geographical regions partitioned into grids;
identifying a user-specified region with a first plurality of points of interests in each of one or more representative categories in the spatial map;
extracting one or more geographical region candidates from a set of geographical region candidates;
searching the extracted set of geographical region candidates with a second plurality of points of interests in each of the one or more representative categories based at least in part on a spatial similarity to comparable points of interest in the one or more representative categories in the user-specified region, the spatial similarity comprises comparable distribution of respective points of interests of the user-specified region and the set of geographical region candidates in the one or more representative categories; and
presenting a predefined number of top geographical region candidates based at least in part on a result of the searching.
19. A computing device comprising:
one or more processors;
a computer-readable storage medium in communication with the one or more processors, the computer-readable storage medium having computer-executable instructions that, when executed, cause the one or more processors to perform acts comprising:
providing a spatial map containing geographical regions partitioned into grids;
identifying a user-specified region with a first plurality of points of interests in each of one or more representative categories in the spatial map;
pruning a set of geographical region candidates;
searching from the pruned set of geographical region candidates for geographical region candidates having a second plurality of points of interests in each of the one or more representative categories based at least in part on a spatial similarity to comparable points of interest in the one or more representative categories of the user specified region, the spatial similarity comprises comparable distribution of respective points of interests of the user-specified region and the set of geographical region candidates in the representative categories; and
presenting a predefined number of top geographical region candidates based at least in part on a result of the searching.
2. The method of
3. The method of
calculating frequencies of one or more categories within each region of the spatial map;
calculating an inverse region frequency of the one or more categories within each region based at least in part on a total number of the grids within the respective region that include points of interest with the respective category;
identifying the representative categories of each region based at least in part on the calculated frequencies of the one or more categories and the inverse region frequency of the one or more categories;
extracting spatial features from the representative categories based at least in part on the identified representative categories; and
calculating bounds of non-extracted spatial features from the representative categories,
wherein the pruning is based at least in part on the bounds of the non-extracted spatial features.
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
11. The system of
calculating frequencies of one or more categories within each region of the spatial map;
calculating an inverse region frequency of the one or more categories within each region based at least in part on a total number of the grids within the respective region that include points of interest with the respective category;
identifying the representative categories of each region based at least in part on the calculated frequencies of the one or more categories and the inverse region frequency of the one or more categories;
extracting spatial features from the representative categories based at least in part on the identified representative categories; and
calculating one or more bounds of non-extracted spatial features from the representative categories,
wherein the extracting the one or more geographical region candidates is based at least in part on the one or more bounds of the non-extracted spatial features.
12. The system of
13. The system of
14. The system of
15. The system of
16. The system of
17. The system of
18. The system of
20. The computing device of
calculating frequencies of one or more categories within each region of the spatial map;
calculating an inverse region frequency of the one or more categories within each region based at least in part on a total number of the grids within the respective region that include points of interest with the respective category;
identifying the representative categories of each region based at least in part on the calculated frequencies of the one or more categories and the inverse region frequency of the one or more categories;
extracting spatial features from the representative categories based at least in part on the identified representative categories; and
calculating one or more bounds of non-extracted spatial features from the representative categories,
wherein the pruning is based at least in part on the one or more bounds of the non-extracted spatial features.
|
This is a continuation application which claims priority to commonly assigned, co-pending U.S. patent application Ser. No. 12/567,667, filed Sep. 25, 2009. Application Ser. No. 12/567,667 is fully incorporated herein by reference.
A wide range of traditional information retrieval is being offered to users by service providers or search engines. The traditional information retrieval services offered may allow a user to provide a set of keywords or terms to a search engine. In return, the search engine provides a list of items that are relevant to the keywords or the terms by retrieving text documents.
A problem that occurs with the traditional information retrieval, however, is when the user wants to find particular locations by representative categories in a geographical region. For example, the user travelling in a new city may have limited knowledge about the area. Since the user may also have limited time, it is highly desirable to find locations with a desired mixture of local sights and/or attractions to visit during this limited time.
Another problem with the traditional information retrieval is that it does not help identify geographical regions that may be considered potential high-risk areas prone to outbreak of diseases. Thus, the problem is not able to identify the high-risk areas to alert a traveler to avoid that geographical region.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
This disclosure describes geographical recommendation services that, for example, searches and recommends points of interests based on a user-specified region. Points of interests include spatial objects (e.g., buildings, landmarks, rivers, parks) and their distributions in a geographical region. The process searches for points of interests by partitioning a spatial map into grids to identify representative categories located in each of the grids. In response to the user-specified region, a set of geographical candidates containing the representative categories is retrieved. The process determines whether the user-specified region and the set of geographical candidates include similar representative categories and spatial distributions of the representative categories. Then the process recommends the top ranked geographical candidates that have similar content information to the user-specified region.
The Detailed Description is set forth with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items.
Overview
As discussed above, conventional services or search engines may not always provide an effective way of searching regions that are similar in content information to a region specified by the user. For example, in some instances, it may be difficult to identify how to measure similarities in content information between the regions. Moreover, conventional services or search engines may not be able to readily incorporate the distribution of the representative categories while trying to measure similarities between the regions. This disclosure describes various illustrative ways of searching to recommend geographical regions that are similar to a user-specified region or a query region on a spatial map. For example, by determining whether the user-specified region and a set of geographical candidates have similar content information including common geometric properties, common representative categories, and common spatial distributions of representative categories. The process provides the top ranked geographical regions from the set of geographical candidates, that have similar content information to the user-specified region. Thus, the techniques described in detail below provide ways to search and to recommend points of interests in regions that are similar to the user-specified region.
In an implementation, the techniques for searching and recommending similar regions employ a spatial vector space model. The vector space model measures similarity by analyzing whether the user-specified region and a candidate region have a significant overlap in their representative categories and whether the points of interests of the common representative categories among these two regions have a similar spatial distribution. The vector space model evaluates the similarity of the two regions by analyzing a cosine similarity of corresponding feature vectors of the two regions. Furthermore, to minimize the effects of scaling and to allow for rotation invariant, two new features capture the spatial distribution of points of interests: mutual distance vector or reference distance vector.
In another implementation, the techniques employ a quadtree-based heuristic region search approach. The quadtree process partitions the spatial map into a hierarchical structure and builds a quadtree structure for quick retrieval of points of interests in a region. For instance, the process uses these index structures to perform region search queries efficiently. Given the user-specified region, the process analyzes a shape and a size of the user-specified region and determines an appropriate quadtree layer to initiate a similar region search process. At the same time, the process may compute values for an inverse region frequency of category to derive the representative categories of the user-specified region. Next, a prune-and-refine process quickly reduces the search space that is unlikely to be in the top most similar regions.
While aspects of described techniques can be implemented in any number of different computing systems, environments, and/or configurations, implementations are described in the context of the following illustrative computing environment.
Illustrative Environment
The environment 100 includes an illustrative computing device 102, which may take a variety of forms, including, but not limited to, a desktop computer, a portable handheld computing device (e.g., a personal digital assistant, a smart phone, a cellular phone), a thin client, a laptop computer, a media player, or any other device capable of connecting to one or more network(s) 104 to access network services, a network service provider, a web site, web entity, and the like. A user 106 may employ the illustrative computing device 102 to connect to the one or more network(s) 104.
The one or more network(s) 104 represents any type of communications network(s), including multiple different types of networks, interconnected with each other and functioning as a single large network (e.g., the Internet or an intranet). The network 104 may include wire-based networks (e.g., cable), wireless networks (e.g., cellular, satellite, etc.), cellular telecommunications network(s), and IP-based telecommunications network(s) (e.g., Voice over Internet Protocol networks). The network 104 may use any number of protocols and configurations to enable the computing device 102 to access other devices, content, information, and resources.
The computing device 102 may include a geographical region module 108 to implement searching for geographic regions with similar POIs to the user-specified region, that may be accessed on the computing device 102. In some implementations, this geographical region module 108 may be available as part of the web browser, may be incorporated into a search engine, or may be available as an application on the computing device 102. In particular, the geographical region module 108 searches and provides recommendations of regions with similar POIs to the query region specified by the user 106. The terms user-specified region and query region are used interchangeably to refer to the region that the user 106 specifies.
The user-specified region may be a place the user has visited, a place the user would like to visit, or a place the computing device specifies based at least in part on the user's present location as a center of a certain window size. In an implementation, the user 106 may draw a rectangle around the query region at the place he or she is visiting on the spatial map. Thus, the region identified in this rectangle is the query region 110 or the user-specified region 110, such as a shopping mall. Shown is an example of a set of candidates that may be in a geographical region 112.
Unlike a traditional text query that searches based on keywords, the geographical region module 108 finds the top most similar regions to the user-specified region using an algorithm. The algorithm identifies a set of candidates in the regions if there is similar content information of the POIs in the regions. The algorithm evaluates whether the POIs in the query region 110 and the set of candidates 112 have similarities that are measured by geometric properties, content properties, and spatial properties. The similarity measures look for common geometric properties (i.e., scales, shapes, sizes), common content properties (i.e., POIs categories, representative categories), and common spatial properties (i.e., distribution of POIs of representative categories, reference points). The algorithm performs the search promptly to provide the top candidates. In the illustrated example, the top regions 112 with similar POIs may be presented to the user 106 on a spatial map, as an enlarged view, or as a list.
The environment 100 may include one or more web site servers 114(1), 114(2), . . . , 114(S) which may be a representative set of servers that is accessible via the network(s) 104. The geographical region servers 114 may be independent servers, or a collection of servers that are configured to perform larger scale functions (e.g., a server farm or a datacenter), or a set of servers configured to host one or more sites (e.g., web sites) accessible by the network 104. In the illustrated example, the servers 114 may represent private servers that serve content and programming to the computing device 102, the thin client, and the like. Alternatively, the servers 114(1)-114(S) may represent a wireless services provider that provides content to wireless devices. In still other implementations, the servers 114(1)-114(S) may be configured to host a service provider, such as a web site accessible by the computing device 102 via the Internet.
These various arrangements exhibit examples of environments where a server-side geographical region module 116 may be employed. In the illustrated example shown in
In another implementation, a server-side geographical region module 116 may be located on the geographical server 114 or may be part of an operating system browser on the server accessible by a computing device. In some instances, the geographical region module on the computing device may be executed with a server-side geographical region module to provide recommendations of geographical regions with similar POIs to the user-specified region.
The memory 202 may also include an operating system 206 and a user interface (UI) module 208 that, when executed on the processor 200, collectively facilitate presentation of a user interface on a display of the computing device 102. The user interface module 208 may provide a visual representation of the spatial map, where the user 106 may draw a rectangle in one color (e.g., red color) to specify the query region 110. For example, by providing a visual representation to the user 106 confirms the query region 110 selected may include the representative categories that are desired. This provides assurance to the user 106 when receiving the top recommendations for the geographical regions with POIs, that are similar to the user-specified region 110. In an implementation, the similar geographical regions with POIs may be displayed with a second color (e.g., blue color). Thus, the user 106 may visually confirm there are similar representative categories and similar spatial distribution of POIs to the query region.
Furthermore, the user interface module 208 of the computing device 102 may, in some implementations, visually present a list of the top geographical regions with POIs identified. This visual representation of a list allows the user 106 to visually verify that the representative categories have been identified for the geographical regions. For example, the list may describe Region Candidate 1 that includes restaurants, shopping malls, and theatres with their addresses, while Region Candidate 2 includes restaurants and hotels with their addresses. Thus, the user may quickly scan the list to select a region.
Furthermore, the computing device 102 may visually present the geographical regions with POIs in a representation with geographical coordinates, such as streets and highways. By visually illustrating what and where the representative categories are, helps the user 106 know what representative categories are available and where the representative categories are located. For example, the user 106 may be travelling in New York City, wants to find a restaurant close to a theatre. The user 106 may draw a rectangle around restaurants or theatres on a certain street located in Manhattan, representing the categories of the user-specified region 110. In response, the geographical region module 108 in operation with the user interface module 208 provides and displays the top recommendations of geographical regions with POIs that are similar to the user-specified query 110. The top recommended geographical regions may be shown with rectangles around the regions in different colors. For example, in an implementation, the rectangles may be based on colors ranging in order of rank.
The memory 202 may include a content storage 210 for locally storing representative categories of points of interests on the spatial map. The content stored may include representative categories identified through: spatial objects, published telephone listings, zip codes, city information, graphical representation of the set of geographical coordinates, and the like. Some of the information may include business entities, each having their own properties of name, category, and GPS coordinate. Storing the representative categories of points of interests in the content storage 210 offers the user 106 accessibility to the content, if there is no network service available. As mentioned, the servers 114 may host some or all of the content, such as the spatial maps, applications, and may store some or all of the content, based on the network service provider.
The computing device 102 as described above may be implemented in various types of systems or networks. For example, the computing device may be a part of, including but is not limited to, a client-server system, a peer-to-peer computer network, a distributed network, an enterprise architecture, a local area network, a wide area network, a virtual private network, a storage area network, and the like.
Turning to the contents of the memory 304 in more detail, the memory 304 may store an operating system 310, the server-side geographical region module 116, a geographical region user interface module 312, and one or more applications for implementing all or a part of the searching geographical region services. The geographical region user interface module 312 facilitates a representation of the geographical regions with POIs similar to the user-specified query region on a display of a user interface to receive selections from the user 106. The server-side geographical region module 114 and the geographical region UI module 312 may be stored on the geographical region server 114, in addition to or instead of the individual computing device 102.
The memory 304 in this implementation may also include a quadtree module 314, an extraction spatial logic 316, a pruning logic 318, a content storage 320, and a communication connection(s) 322.
The quadtree module 314 provides a heuristic region search approach. The quadtree module 314 partitions the spatial map into a hierarchical structure and builds a quadtree structure for quick retrieval of POIs. The quadtree module 314 uses the index structures to perform region search queries efficiently. Given a user-specified query, the process analyzes a shape and a size of the user-specified region and determines an appropriate quadtree layer to initiate the similar region search process. A detailed discussion of the quadtree follows in
Once the starting level of the quadtree and the representative categories of the region are known, a prune-and-refine procedure occurs to remove the search space that is unlikely to be in the top-K most similar regions. The extraction spatial logic 316 extracts the representative categories from the search region. Occurring about the same time as the quadtree module 314 interacting, the extraction spatial logic 316 may compute category frequency values for each category on the user-specified query region and may maintain the top-m categories with the largest category frequency values.
The pruning logic 318 works in conjunction with the quadtree module 314. The pruning logic 318 effectively prunes the region by storing key statistical information at each node in the quadtree structure. Each node maintains a lower bound and an upper bound which are useful for pruning the candidate regions by the pruning logic 318.
The content storage 320 provides suitable storage options for the content based at least in part on storing representative categories for points of interests on the spatial map. The content stored may include representative categories identified through: spatial objects, published telephone listings, zip codes, city information, graphical representation of the set of geographical coordinates, and the like. The content storage 320 may also manage storage options for the content, such as the content from the computing device 102, the content stored in the content storage 210, and the content stored in the server-side content storage 320.
The server 114 may also contain communications connection(s) 322 that allow the processor 302 to communicate with the computing device 102, other network servers, network storage, and/or other devices on the network(s) 104. The server 114 may also include one or more known input device(s), such as a keyboard, mouse, pen, voice input device, touch input device, etc., and output device(s), such as a display, speakers, printer, etc. All these devices are well known in the art and are not discussed at length here.
Any memory described herein may include volatile memory (such as RAM), nonvolatile memory, removable memory, and/or non-removable memory, implemented in any method or technology for storage of information, such as computer-readable instructions, data structures, applications, program modules, emails, and/or other content. Also, any of the processors described herein may include onboard memory in addition to or instead of the memory shown in the figures. The memory may include storage media such as, but not limited to, random access memory (RAM), read only memory (ROM), flash memory, optical storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the respective systems and devices.
The geographical region server as described above may be implemented in various types of systems or networks. For example, the geographical region server may be a part of, including but is not limited to, a client-server system, a peer-to-peer computer network, a distributed network, an enterprise architecture, a local area network, a wide area network, a virtual private network, a storage area network, and the like.
Illustrative Processes
For ease of understanding, the methods 400 and 800 are delineated as separate steps represented as independent blocks in
Equations used for the process are described below. An equation illustrates the search functionality and recommends geographical regions with similar content information. Using the spatial map, a query region Rq, two coefficients to control an area of a region u1 and u2, the process finds the top-k most similar regions to Rq on the spatial map. The equation to find the area Ri is:
Ri is a return region or in a set of candidates and that any two regions do not have a large overlap. An expected size of returned similar regions may satisfy the following inequality: 41
a*size of original region=<size of returned region<=b*size of original region. For example, a may be 0.7, b may be 1.3. These parameters may ensure the size of the returned regions are similar to the query region.
In an equation, P is the spatial map, and T is a set of POI categories, such that T={C1, C2, . . . CK}. Each POI may be labeled with multiple POI categories. For example, a building is labeled both as a cinema and a restaurant, if the building houses a cinema and has at least one restaurant inside.
In another equation, the POI database D is a set of POIs. Each POI, o in D is presented by a tuple o=<po; To>, where po=(xo,yo) denotes the location of o, and To is the set of o's POI categories. The process uses |Ci| to denote the number of POI tuples with category Ci. Thus the number of POI tuples with category may be represented as:
|Ci|=|{o|ΓoεCi}∥
A region RεP is a spatial rectangle bounded by [Rxmin,Rxmax]×[Rymin, Rymax] A POI o=po; Γo is believed to have occurred in region R if poεRDiK={o|poεR^ΓoεCi} is a set of objects with category Ci occurring in region R.
In block 404, the process calculates the Category Frequency (CF) of the category Ci in region Rj, may be denoted as CFi;j. This is the fraction of the number of POIs with category Ci occurring in region Rj to the total number of POIs in region Rj, shown as:
where ni;j is the points number of category Ci in region Rj. The relevance of a category Ci depends on the distribution of POIs with category Ci on the entire map. These equations are used to identify the category frequency of the category in the region.
In block 406, the process partitions the spatial map into grids (or regions) by imposing a gx×gy grid on the spatial map. The Inverse Region Frequency (IRF) of category Ci, may be denoted as IRFi. The IRF is a logarithm of a fraction of a total number of grids to a number of grids that contain POIs with category Ci. Shown is the equation for Inverse Region Frequency as:
With CF and IRF calculated, the significance of a category Ci, in region Rj, may be denoted as CF-IRFi,j. This equation identifies the representative categories by:
CF−IRFi,j=CFi,j×IRFi
Furthermore, a CFIRF vector space model represents each region by a set of representative categories' CFIRF values. The information content of a candidate region, Ri and the query region, Rq, may be represented by vectors. The vector representations may be shown as:
{right arrow over (Rl)}=(w1,i,w2,i, . . . ,wK,i)
{right arrow over (Rq)}=(w1,q,w2,q, . . . ,wK,q)
where wk,i and wk,q are the CFIRF feature values of category Ck in regions Ri and Rq, respectively. Furthermore, ω=CF−IRF may be used.
The CF-IRF identifies the representative categories of a region including the query region and grid regions to be searched. When identifying the representative categories of the query region, the process determines a corresponding level of the quad-tree where the query should be searched. After the quadtree level is determined, the number of grids on the level is known and the CF-IRF may be calculated. The top m categories with relatively large CF-IRF values may be selected as the representative categories, where m is a predefined parameter.
The information content similarity of two regions, Ri and Rj, is the cosine similarity of the corresponding feature vectors of Ri and Rj. The spatial vector space model (SVSM) ranks the regions according to their cosine similarity measures, described as:
Using the equation shown above, the vector space model regards regions having similar CFIRF category values to be similar and ranks the regions according to their cosine similarity measures.
In block 408, after partitioning the spatial map of this database, the process builds a hierarchical quadtree structure to facilitate the construction of multi-scale regions. In the quadtree, the root node denotes the map and each non-leaf node corresponds to one of the four partitioned cells from its parent's cell. At the lowest level, each leaf node corresponds to the partitioned cell with the smallest granularity.
The quadtree structure enables the efficient handling of multi-granularity similar region queries. This is because the process may adaptively select the different levels of granularity by accessing the quadtree nodes at an appropriate level.
From the quadtree 408, the process moves to the right to apply category indexing as shown in block 410. Category indexing may be used to conducting a search by indexing a particular category. This may be used as input for a layer selection in
In block 412, the process constructs an inverted tree index on the representative categories to facilitate similar region search. The root node of the inverted tree has K entries, where each entry corresponds to a category. Each category, say Ci, of a non-leaf node is associated with a child node that has four entries. The entry value is 1 if the corresponding partitioned region has the Ci as a representative category; otherwise the entry value will be 0. This inverted list tree is recursively built until it reaches a leaf node of the quadtree structure or all four entries have value 0. Based on this inverted tree index, the process may quickly identify the cells that have similar categories to the query region. The inverted tree 412 is used as input for category-based pruning in
In block 414, the process identifies representative categories of a region for the query region and grid regions to be searched. Based on determining the number of grids in the level described above, the process moves to identify whether these are representative categories. The process determines the corresponding level of quad-tree where the geographical regions should be searched. Once this level of quad-tree is determined, the number of grids on each level is known to calculate the CF-IRF.
In block 416, the process extracts spatial features from the representative categories. The process allows effective region pruning by storing the key statistical information at each node in the quadtree. Each node maintains the lower bound and upper bound of feature entries. The feature entries are defined as the lower bound feature vector of a node B, denoted as Blb, is (f1, lb, f2, lb, . . . fn, lb), where fi,lb is the minimum i-th feature entry of all descendant nodes of B. The upper bound feature vector of a node B, denoted as Bub, is (f1, ub, f2, ub, . . . fn, ub) where fi, ub is the maximum i-th feature value of all descendant nodes of B.
Depending on the similarity measure that is adopted, the bounds may be one of the following:
Lemma 1: Let {right arrow over (Rq)}=(f1,q, f2,q, . . . , fn,q) to be the feature vector of query region, σ to be the cosine similarity threshold of top-k regions. A node B can be pruned if for any feature entry fi,q there is
Proof: Let fi,j to be the i-th feature entry of region Rj where RiεB. Then fi,lb≦fi,j≦fi,ub and |{right arrow over (Blb)}|≦|{right arrow over (Rj)}|≦{right arrow over (Bub)}| Assume that:
For the i-th feature entry fi,j, the process has
By summing up the inequalities, the process shows:
{right arrow over (Rj)}·{right arrow over (Rq)}=Σp=1nfp,j·fp,q≦σ·|{right arrow over (Rj)}|·|{right arrow over (Rq)}|.
Based on this, cos({right arrow over (Rj)},{right arrow over (Rq)})≦σ, which means that any region Rj under B will not have a larger similarity than the top-k region similarity threshold.
With Lemma 1, the process may prune all node B that have no chance of satisfying the similarity threshold σ. For example, suppose the quadtree node B has four child nodes, B1, B2, B3, and B4. Each feature vector of child node has five entries.
{right arrow over (B1)}=(0.1,0.3,0.1,0.8,0.0)
{right arrow over (B2)}=(0.1,0.7,0.2,0.7,0.0)
{right arrow over (B3)}=(0.0,0.3,0.1,0.8,0.2)
{right arrow over (B4)}=(0.2,0.4,0.2,0.6,0.1)
The process has {right arrow over (Blb)}=(0.0,0.3,0.1,0.6,0.0) and {right arrow over (Bub)}=(0.2,0.7,0.2,0.8,0.2). Let the feature vector of query region is {right arrow over (Rq)}=(0.9,0.1,0.9,0.1,0.8) and δ=0.95. The result is
Thus, the node B can be pruned because each feature entry product of {right arrow over (Rq)} and {right arrow over (Bub)} is less than 0.2468.
Block 418 calculates feature bounds which helps speed up the search. Once the feature bounds are identified, this may be applied in category-based pruning in
In this implementation, restaurants may be represented by triangles, stores may be represented by circles, and theatres may be represented by stars. An example of a query region is shown in 502 with restaurants, stores, and a theatre closely distributed.
Shown along 504 are spatial distributions of restaurants, stores, and theatres in a) a shopping mall and b) a shopping street. This illustrates common representative categories of restaurants, stores, and theatres. However, the two illustrations show different scales, such as a small scale for the shopping mall while a large scale for the shipping street. Furthermore, the spatial distributions of the shopping mall and the shopping street are very different as the distributions of the POIs for each category are drastically different in the two figures. Thus, the shopping mall and the shopping street are not similar. However, the shopping mall is similar to the query region 502 and would be selected as having common representative categories, common size and scale, and common spatial distributions.
Shown along 506 are spatial distributions of restaurants, stores, and theatres in a c) living area and in an d) university town. This illustrates the living area and the university town are not similar because the overlap in their common categories is only 2 out of 3. The common categories are restaurants represented by triangles and stores represented by circles. There are no theatres represented by stars but includes rectangles. Furthermore, there are different shapes, the living area is in a small rectangle while the university town would include multiple rectangles. These spatial distributions of the POIs corresponding to the representative categories may be differentiated by the spatial vector space model. To minimize the effects of scaling and to allow for rotation invariant, the process uses two features to capture the spatial distributions of these POIs: mutual distance vector and reference distance vector.
Shown below is an equation to measure the mutual distance of h(P; Q)
where dist(p, q) is the Euclidean distance function.
A small mutual distance of h(P; Q) means that all the POIs in sets P and Q are close. The mutual distance is also consistent with the Hausdorff distance, which is a widely used distance function in pattern recognition.
A region R can be characterized by the mutual distances among the sets of POIs in R. Given K number of representative categories, R can be represented as a vector of K2 entries, denoted as {right arrow over (HR)}=(h11, h12, . . . , h1K . . . , hKK, where hij is the mutual distance of the set of POIs in R with category Ci to the set of POIs in R with category Cj.
Note that the mutual distance is an asymmetric metric, i.e. h(P,Q)≠h(Q, P). The process may also measure the closeness within a set of POIs of the same category, say P=(p1, p2, . . . pm) as follows:
As mentioned above, a small mutual distance of h (P; P) implies that the POIs of P are close to each other. On the other hand, a large h(P; P) means that the POIs of P have a sparse distribution.
While the mutual distance vector 600 accurately captures the spatial distribution among the POIs of different categories in a region R, it has been observed that most users tend to use some reference points for determining region similarity. With this in mind, the process captures the spatial distributions of the POIs with respect to a set of reference points. This is based on the observation that users usually compare the distribution by the distances between the POIs and the region icons or corners.
The similarity of regions is determined by the similarity of feature vector sets. Given two regions Ri and Rj and their feature vector sets IRi={{right arrow over (I1,l)}, . . . {right arrow over (IC,l)}} and IRj={{right arrow over (I1,j )} . . . {right arrow over (IC,j)}}, the similarity is computed by selecting the best similar feature vector from IRj for each feature vector in IRi, and compute the average similarity value. The reference distance is an average distance of all the points in P/Q to each of the reference points. Given a region R, a set of POIs P, and a set of reference points O={O1, O2, O3, . . . Oc}. The distance of P to the i-th reference point oiεO is measured by:
Assume region R has K different categories of POIs. The process uses ri,j to denote the distance of POIs with category Ci to the reference point Oi. The distance of K categories to the reference point Oi is a vector of K entries, shown below:
{right arrow over (Il)}=(r1,i,r2,i, . . . ,rK,i).
The selection of reference points is application dependent. The process may need at least reference points to uniquely determine a position on the spatial plane. The larger number of reference points will give a more accurate representation of the spatial distributions among the POIs, while incurring more computational cost.
For example, the shadowed areas in the quadtree 700 correspond to the shadowed nodes in the inverted list 702. In the first level, shadow area 1 in quadtree 700 corresponds to the shadow area 1 in the inverted list 702. In the second level, shadow areas 12 and 13 in the quadtree 700 corresponds to 1,1, in the inverted list 702.
A search strategy is described based on the quadtree structure. Given a query region, the process adjusts the search granularity on the quadtree based on the query region by accessing the lowest level of the quadtree. The lowest level of the quadtree has an area that is greater than μ1×area(Rq).
An algorithm, algorithm 1 is shown below to give an illustration of the region search. The purpose is to select a bucket of level lsearch in the quadtree as a seed and gradually expand this bucket to a region of suitable shape and large similarity value.
Algorithm 1: Region Search (Rq, T, s, k)
Input: Query region Rq;
Quadtree T;
Number of return regions s;
Number of representative categories m.
Output: Top-k similar regions
1 Compute the search level lsearch on T based on Rq;
2 CM = ExtractCategory(Rq);
3 Adjust ({right arrow over (Rq)}, CM);
4 R = Ø;
5 δ = 0;
6 SearchQTree({right arrow over (Rq)}, T.root, δ, R);
7 return R;
8 Procedure SearchQTree({right arrow over (Rq)}, B, δ, R, CM);
9 if B has CM categories Λ B cannot be pruned by
Lemma 1 then
10
If B.level < lsearch then
11
for each child node (B′ ∈ B) do
12
SearchQTree (Rq, B′, δ, R)
13
else
14
R =RegionExpansion(Rq, B′)
15
R = R ∪ R;
16
update δ;
17 Function RegionExpansion (Rq, R)
18 repeat
19
for each dir ∈ {LEFT, RIGHT, DOWN, UP} do
20
R″ =expand(R,dir);
21
dir = arcmax(Sim(Rq, R″))
22
R′ =expand(R,dir);
23 until Sim(Rq, R) ≦ Sim(((Rq,R′);
24 return R′
Line 1 computes the proper search level on the quadtree T. The bucket of search level will be greater than the minimal area of returned regions. Line 2 extracts the representative categories from the search region Rq. The function ExtractCategory computes the CFIRF values for each category on Rq and only maintains the top-m categories with the largest CFIRF values. Line 3 adjusts the feature vector of Rq. If the feature vectors are category CFIRF vectors or reference feature vectors, the entries which correspond to the top-m representative categories remains and the other entries are set to be zero. If the feature vector are mutual influence feature vector, the entries which correspond to the top-m representative category pairs remain and the other entries are set to zero.
Line 4 and Line 5 initialize the return region set to be an empty set and the similarity threshold δ to be 0. Line 6 calls procedure SearchQTree to find and to prune the candidate regions. Line 9 of Algorithm 1 is the validity checking for the top-k regions. A bucket is valid only if 1) it contains the CM representative categories, and 2) it cannot be pruned by Lemma 1. The inverted tree structure and the feature bounds of buckets facilitate the validity checking. If a bucket is valid, this bucket may contain at least one top-k similar region, which means that its child nodes need to be processed further.
Line 13 recursively calls the procedure to process the child node if has a depth less than lsearch. Otherwise, the process may stop at the level of lsearch because the buckets at the lower levels are too small to be candidate regions. Line 14 expands the bucket of lsearch by calling the function RegionExpansion. Line 15 inserts the expanded region R to the top-k region set R. If R has no overlap with the existing top-k regions, R is inserted into R. Note that R only maintains k regions which have the largest cosine similarity values. Line 16 updates the similarity threshold±based on k-th largest similarity value in R.
Lines 17-24, the RegionExpansion function treats a region as a seed and tries to expand the seed in four candidate directions, and selects the optimal expanded region which give the largest similarity value. The step width of each expansion is the cell side of the quadtree leaf node in order to minimize the scope of expansion, which eventually approach the local most similar region. The expansion is repeatedly performed till there is no increase in the similarity value (Line 23). Finally, Line 7 returns the top-k regions. If the number of regions in R is less than k, the process may decrease the value of m by 1 in Line 9, and search the cells which share exact mi1 common representative categories and do not pruned by Lemma 1. The process repeatedly decreases the m value by 1 till the number of return regions in R reaches k.
At block 802, the query region or the user-specified region is identified or selected by the user 106, by highlighting the query region on the spatial map. In an implementation, the user 106 may specify the POIs by drawing a rectangle around the query region on the spatial map. The region highlighted within the rectangle is the user-specified region or the query region. For example, the user is travelling in Seattle, Wash., accesses the spatial map for Seattle, and selects sights or attractions specific to the Seattle region, such as the Space Needle. The user-specified region with the POI is the Space Needle, which may be highlighted by a red color rectangle. The process may retrieve similar POIs in the geographic region on the spatial map, identifying the geographical regions with the top most similar scores. The process searches and recommends sights or attractions specific to the Seattle region, such as the Pike Place Market, the Waterfront, the Woodland Park Zoo, the Seattle Art Museum, and the like. The POIs in the geographical region that are similar in content to the POIs in the user-specified region may be shown with blue lines around them.
In block 804, the process detects the representative categories based on using the equations described above in 404 and 406 to calculate category frequency CF, inverse region frequency IRF, and significance of a category in a region CF-IRF. For convenience, the equations are reproduced below:
In block 806, a layer selection receives input from the category indexing 410. The layer selection 806 analyzes a shape and a size of the user-specified region and determines an appropriate quadtree layer to initiate the similar region search process. During this time, the process computes the CFIRF values to derive the representative categories of the user-specified region. Thus, the layer selection 806 identifies the quadtree layer based on the information received from the user-specified region and the category index information. Once the starting level of the quadtree and the representative categories of the user-specified region are known, a prune-and-refine procedure may reduce the search space that is not likely to be in the top-k most similar geographical regions.
Turning to block 808, the process performs representative categories pruning on the set of candidates. Representative category-based pruning includes receiving input of the representative categories and information from the quadtree layer along with content received from the inverted tree list 412 and feature bounds 418. The category-based pruning determines there is some overlap of representative categories with the user-specified region.
The process performs category-based pruning 808 on the set of candidates. For example, a candidate region may have some overlaps of representative categories with the query region. An equation to determine overlap based at least in part on cosine similarity. For pruning, the cosine similarity should exceed a threshold, as shown in the equation below:
Block 810 performs spatial feature-based pruning. For spatial feature-based pruning 810, the equations to consider are:
Block 812 expands the region. The process selects the seeds regions that do not need to be pruned. The process expands the seed regions using the functionality shown below:
Function RegionExpansion (RqR)
repeat
foreach dir ∈ {LEFT, RIGHT, DOWN, UP} do
R″ =expand(R, dir);
dir = arcmax(Sim(Rq,R″));
R′ = expand(R, dir);
until Sim(Rq,R)≦Sim(Rq,R′);
return R′
Block 814 provides recommendations for the top ranking geographical regions that have similar content information to the user-specified region.
In another implementation, the user may specify an area that is considered an area identified for a particular disease. Based on the user-specified area for this area, the process may identify the areas that are prone to the particular disease. Thus, travelers may desire to avoid areas that may be prone to this particular disease or potential to breakouts.
As discussed above, certain acts in processes 400 and 800 need not be performed in the order described, may be modified and/or may be omitted entirely, depending on the circumstances. Various instructions, methods, techniques, applications, and modules described herein may be implemented as computer-executable instructions that are executable by one or more computers, servers, or telecommunication devices. Generally, program modules include routines, programs, objects, components, data structures, etc. for performing particular tasks or implementing particular abstract data types. These program modules and the like may be executed as native code or may be downloaded and executed, such as in a virtual machine or other just-in-time compilation execution environment. The functionality of the program modules may be combined or distributed as desired in various implementations. An implementation of these modules and techniques may be stored on or transmitted across some form of computer-readable media.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as illustrative forms of implementing the claims.
Zheng, Yu, Xie, Xing, Sheng, Chang
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5428546, | Oct 16 1992 | TELEMATICS CORPORATION | Method and apparatus for tracking vehicle location |
5802492, | Jun 24 1994 | Garmin Switzerland GmbH | Computer aided routing and positioning system |
5845227, | Feb 01 1991 | Method and apparatus for providing shortest elapsed time route and tracking information to users | |
5904727, | May 17 1995 | TELEMATICS CORPORATION | Graphical fleet management methods |
6023241, | Nov 13 1998 | TUMBLEWEED HOLDINGS LLC | Digital multimedia navigation player/recorder |
6091359, | Jul 14 1997 | Continental Automotive Systems, Inc | Portable dead reckoning system for extending GPS coverage |
6091956, | Jun 12 1997 | LBS INNOVATIONS, LLC | Situation information system |
6122628, | Oct 31 1997 | International Business Machines Corporation; IBM Corporation | Multidimensional data clustering and dimension reduction for indexing and searching |
6128279, | Jan 13 1998 | TUMBLEWEED HOLDINGS LLC | System for balancing loads among network servers |
6219662, | Jul 10 1997 | International Business Machines Corporation | Supporting database indexes based on a generalized B-tree index |
6243647, | Jan 28 1999 | MEDIATEK INC | Three dimensional display for time multiplexed global positioning system cell location beacon system |
6317684, | Dec 22 1999 | AT&T MOBILITY II LLC | Method and apparatus for navigation using a portable communication device |
6317686, | Jul 21 2000 | ITERIS, INC | Method of providing travel time |
6351775, | May 30 1997 | SAP SE | Loading balancing across servers in a computer network |
6356838, | Jul 25 2000 | SC INNOVATIONS, INC | System and method for determining an efficient transportation route |
6385539, | Aug 13 1999 | 21ST CENTURY GARAGE LLC | Method and system for autonomously developing or augmenting geographical databases by mining uncoordinated probe data |
6411897, | Jul 10 2000 | KESTREL TRANSPORTATION, LLC | Method to schedule a vehicle in real-time to transport freight and passengers |
6424370, | Oct 08 1999 | Texas Instruments Incorporated | Motion based event detection system and method |
6427122, | Dec 23 2000 | American GNC Corporation | Positioning and data integrating method and system thereof |
6430547, | Sep 22 1999 | IBM Corporation | Method and system for integrating spatial analysis and data mining analysis to ascertain relationships between collected samples and geology with remotely sensed data |
6446121, | May 26 1998 | Cisco Technology, Inc | System and method for measuring round trip times in a network using a TCP packet |
6493650, | Jan 27 2000 | Optimus Corporation | Device for automatic documentation of crash scenes |
6496814, | Jul 19 2000 | International Business Machines Corporation | Method and system for integrating spatial analysis, and scheduling to efficiently schedule and monitor infrastructure maintenance |
6513026, | Jun 17 2000 | Microsoft Technology Licensing, LLC | Decision theoretic principles and policies for notification |
6516272, | Dec 23 2000 | American GNC Corporation | Positioning and data integrating method and system thereof |
6553310, | Nov 14 2000 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method of and apparatus for topologically based retrieval of information |
6584401, | Nov 27 2001 | DIDI HK SCIENCE AND TECHNOLOGY LTD | Automatic gathering and analysis of data on commute paths |
6606643, | Jan 04 2000 | GOOGLE LLC | Method of automatically selecting a mirror server for web-based client-host interaction |
6611881, | Mar 15 2000 | Personal Data Network Corporation | Method and system of providing credit card user with barcode purchase data and recommendation automatically on their personal computer |
6615130, | Mar 17 2000 | MAKOR ISSUES AND RIGHTS LTD | Real time vehicle guidance and traffic forecasting system |
6618507, | Jan 25 1999 | Mitsubishi Electric Research Laboratories, Inc | Methods of feature extraction of video sequences |
6625319, | Mar 30 1999 | Koninklijke Philips Electronics N V | Image compression using content-based image similarity |
6724733, | Nov 02 1999 | Oracle America, Inc | Method and apparatus for determining approximate network distances using reference locations |
6732120, | Sep 03 1998 | Amazon Technologies, Inc | System and method for processing and display of geographical data |
6785704, | Dec 20 1999 | GOOGLE LLC | Content distribution system for operation over an internetwork including content peering arrangements |
6816779, | Feb 15 2002 | International Business Machines Corporation | Programmatically computing street intersections using street geometry |
6904160, | Oct 18 2000 | Red Hen Systems, Inc. | Method for matching geographic information with recorded images |
6919842, | Mar 06 2003 | Samsung Electronics Co., Ltd. | Hybrid navigation system using neural network |
6925447, | Feb 04 2000 | Medtronic, Inc | Responsive manufacturing and inventory control |
6965827, | Oct 30 2000 | FLUENSEE, INC | Method and system for tracking moving objects |
6970884, | Aug 14 2001 | International Business Machines Corporation | Methods and apparatus for user-centered similarity learning |
6981055, | Aug 22 2000 | INTERNAP HOLDING LLC | Method and system for optimizing routing through multiple available internet route providers |
7003555, | Jun 23 2000 | LOOKINGGLASS CYBER SOLUTIONS, INC | Apparatus and method for domain name resolution |
7013290, | Aug 03 2001 | INTENTIONIZE, LLC | Personalized interactive digital catalog profiling |
7013517, | Dec 13 2002 | Maytag Corp. | Rotating/tipping agitator for a washing machine |
7031517, | Oct 02 1998 | Canon Kabushiki Kaisha | Method and apparatus for segmenting images |
7062562, | Apr 11 2001 | Cisco Technology, Inc. | Methods and apparatus for content server selection |
7111061, | May 26 2000 | AKAMAI TECHNOLOGIES, INC | Global load balancing across mirrored data centers |
7136932, | Mar 22 1999 | MEC MANAGEMENT, LLC | Fictitious domain name method, product, and apparatus |
7152118, | Feb 25 2002 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | System, method and computer program product for caching domain name system information on a network gateway |
7155456, | Dec 15 1999 | Microsoft Technology Licensing, LLC | Storing and recalling information to augment human memories |
7171415, | May 04 2001 | Oracle America, Inc | Distributed information discovery through searching selected registered information providers |
7194552, | Mar 22 1999 | MEC MANAGEMENT, LLC | Method, product, and apparatus for requesting a network resource |
7197500, | Oct 25 1996 | HERE GLOBAL B V | System and method for use and storage of geographic data on physical media |
7203693, | Jun 12 2001 | IRON GATE SECURITY, INC | Instantly indexed databases for multimedia content analysis and retrieval |
7219067, | Sep 10 1999 | GE GLOBAL SOURCING LLC | Total transportation management system |
7228359, | Feb 12 2002 | Cisco Technology, Inc. | Methods and apparatus for providing domain name service based on a client identifier |
7233861, | Dec 08 2003 | GM Global Technology Operations LLC | Prediction of vehicle operator destinations |
7239962, | Feb 21 2003 | Sony Corporation; Sony Electronics Inc. | Method and apparatus for a routing agent |
7281199, | Apr 14 1999 | Level 3 Communications, LLC | Methods and systems for selection of multimedia presentations |
7284051, | Dec 28 1998 | Fujitsu Limited | Relaying apparatus for use in a network system |
7349768, | Apr 25 2005 | The Boeing Company | Evacuation route planning tool |
7366726, | Oct 12 2000 | EXPERIAN TECHNOLOGY LIMITED | Method and apparatus for retrieving data representing a postal address from a plurality of postal addresses |
7389283, | Dec 07 2004 | International Business Machines Corporation | Method for determining an optimal grid index specification for multidimensional data |
7395250, | Oct 11 2000 | TREND MICRO INCORPORATED | Methods and apparatus for outlier detection for high dimensional data sets |
7428551, | Feb 20 2006 | ASIAINFO TECHNOLOGIES NANJING , INC | “Gird plus T Tree” index method for quick orientation in massive memory database |
7437239, | Jan 09 2002 | Webraska Mobile Technologies | Method and device for determining the minimal cost path between two points in a road network |
7437372, | May 10 2002 | International Business Machines Corporation | Systems, methods, and computer program products to reduce computer processing in grid cell size determination for indexing of multidimensional databases |
7447588, | Jul 16 2007 | Wenshine Technology Ltd. | Method and system for partitioning a continental roadway network for an intelligent vehicle highway system |
7479897, | Jun 04 2003 | Bayerische Motoren Werke Aktiengesellschaft | Curve rollover warning system for trucks |
7493294, | Nov 28 2003 | Gula Consulting Limited Liability Company | Mutually adaptive systems |
7519690, | Feb 28 2002 | Sprint Communications Company L.P. | Dynamically updateable parameters in integrated services hub |
7548936, | Jan 12 2005 | Microsoft Technology Licensing, LLC | Systems and methods to present web image search results for effective image browsing |
7561959, | Jun 30 2004 | HERE GLOBAL B V | Method of collecting information for a geographic database for use with a navigation system |
7574508, | Aug 07 2002 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Canonical name (CNAME) handling for global server load balancing |
7584159, | Oct 31 2005 | Amazon Technologies, Inc | Strategies for providing novel recommendations |
7584301, | May 06 2004 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Host-level policies for global server load balancing |
7603233, | Oct 16 2006 | Alpine Electronics, Inc | Map matching method and apparatus for navigation system |
7610151, | Jun 27 2006 | Microsoft Technology Licensing, LLC | Collaborative route planning for generating personalized and context-sensitive routing recommendations |
7660441, | Jul 09 2004 | Southern California, University | System and method for fusing geospatial data |
7685422, | May 18 2004 | Kabushiki Kaisha Toshiba | Information processing apparatus, information processing method, and information processing program |
7706964, | Jun 30 2006 | Microsoft Technology Licensing, LLC | Inferring road speeds for context-sensitive routing |
7707314, | Nov 21 2005 | LIMELIGHT NETWORKS, INC | Domain name resolution resource allocation |
7710984, | Dec 20 2002 | Malikie Innovations Limited | Data transfer from a host server via a tunnel server to a wireless device, and associating a temporary IPV6 address with a temporary IPV4 address for communicating in an IPV4 wireless network with the device |
7739040, | Jun 30 2006 | Microsoft Technology Licensing, LLC | Computation of travel routes, durations, and plans over multiple contexts |
7801842, | Oct 29 2007 | MAXAR MISSION SOLUTIONS INC ; RADIANT MISSION SOLUTIONS INC | Method and system for spatial behavior modification based on geospatial modeling |
7840407, | Oct 13 2006 | GOOGLE LLC | Business listing search |
7860891, | May 10 2002 | HULU, LLC | Reducing index size for multi-level grid indexes |
7904530, | Jan 29 2008 | Xerox Corporation | Method and apparatus for automatically incorporating hypothetical context information into recommendation queries |
7920965, | May 05 2006 | Meta Platforms, Inc | Identifying a route configured to travel through multiple points of interest |
7930427, | Mar 03 2008 | Microsoft Technology Licensing, LLC | Client-side load balancing |
7948400, | Jun 29 2007 | Microsoft Technology Licensing, LLC | Predictive models of road reliability for traffic sensor configuration and routing |
7982635, | Apr 27 2006 | INTELLECTUAL DISCOVERY CO , LTD | Method and system for displaying traveling-position of move object |
7984006, | Sep 18 2007 | Xerox Corporation | Learning a user's activity preferences from GPS traces and known nearby venues |
7991879, | Mar 03 2008 | Microsoft Technology Licensing, LLC | Internet location coordinate enhanced domain name system |
8060462, | Aug 28 2006 | CORTLAND CAPITAL MARKET SERVICES LLC, AS ADMINISTRATIVE AGENT | Mutual interest inferencing system and method |
8117138, | Mar 11 2008 | ServiceNow, Inc | Method and apparatus for location evaluation and site selection |
8135505, | Apr 27 2007 | GROUPON, INC | Determining locations of interest based on user visits |
8190649, | Apr 25 2006 | GOOGLE LLC | Ranking and clustering of geo-located objects |
8219112, | Nov 27 2007 | GOOGLE LLC | Accuracy analysis of wireless base station location |
8275649, | Sep 18 2009 | Microsoft Technology Licensing, LLC | Mining life pattern based on location history |
8458298, | Mar 03 2008 | Microsoft Technology Licensing, LLC | Failover in an internet location coordinate enhanced domain name system |
8562439, | Mar 11 2004 | HERE GLOBAL B V | Geographic area templates for computer games |
8577380, | May 02 2011 | TELEFONICA S A | Method for an automatic identification of urban dense areas from cell phones records |
20010029425, | |||
20020032689, | |||
20020038360, | |||
20020044690, | |||
20020052873, | |||
20020062193, | |||
20020077749, | |||
20020128768, | |||
20030053424, | |||
20030063133, | |||
20030069893, | |||
20030069968, | |||
20030139898, | |||
20030140040, | |||
20030195810, | |||
20030212689, | |||
20030217070, | |||
20030229697, | |||
20040039798, | |||
20040064338, | |||
20040073640, | |||
20040117358, | |||
20040196161, | |||
20040198386, | |||
20040217884, | |||
20040220965, | |||
20040264465, | |||
20050004830, | |||
20050004903, | |||
20050031296, | |||
20050075116, | |||
20050075119, | |||
20050075782, | |||
20050075784, | |||
20050080554, | |||
20050108261, | |||
20050131889, | |||
20050198286, | |||
20050203927, | |||
20050225678, | |||
20050231394, | |||
20050265317, | |||
20050278371, | |||
20060020597, | |||
20060036630, | |||
20060042483, | |||
20060075139, | |||
20060085177, | |||
20060085419, | |||
20060090122, | |||
20060095540, | |||
20060101377, | |||
20060129675, | |||
20060143442, | |||
20060149464, | |||
20060155464, | |||
20060156209, | |||
20060161560, | |||
20060164238, | |||
20060173838, | |||
20060178807, | |||
20060190602, | |||
20060200539, | |||
20060212217, | |||
20060224303, | |||
20060224773, | |||
20060247844, | |||
20060251292, | |||
20060265125, | |||
20060266830, | |||
20070005419, | |||
20070006098, | |||
20070016663, | |||
20070038362, | |||
20070041393, | |||
20070064633, | |||
20070064715, | |||
20070088974, | |||
20070100776, | |||
20070118668, | |||
20070127833, | |||
20070168208, | |||
20070203638, | |||
20070226004, | |||
20080004789, | |||
20080004793, | |||
20080016051, | |||
20080016233, | |||
20080052303, | |||
20080059576, | |||
20080071465, | |||
20080076451, | |||
20080086574, | |||
20080098313, | |||
20080201074, | |||
20080201102, | |||
20080214157, | |||
20080215237, | |||
20080228396, | |||
20080228783, | |||
20080235383, | |||
20080268876, | |||
20080270019, | |||
20080312822, | |||
20080319648, | |||
20080319660, | |||
20080319974, | |||
20090005987, | |||
20090019181, | |||
20090063646, | |||
20090070035, | |||
20090083128, | |||
20090083237, | |||
20090100018, | |||
20090138188, | |||
20090164516, | |||
20090213844, | |||
20090216435, | |||
20090216704, | |||
20090222581, | |||
20090228198, | |||
20090239552, | |||
20090282122, | |||
20090326802, | |||
20100004997, | |||
20100010991, | |||
20100027527, | |||
20100070171, | |||
20100076968, | |||
20100082611, | |||
20100111372, | |||
20100153292, | |||
20100279616, | |||
20100312461, | |||
20110022299, | |||
20110029224, | |||
20110130947, | |||
20110173015, | |||
20110176000, | |||
20110184949, | |||
20110191011, | |||
20110191284, | |||
20110208419, | |||
20110280453, | |||
20110282798, | |||
20110302209, | |||
20120030029, | |||
20120030064, | |||
20120150425, | |||
20120256770, | |||
20130166188, | |||
20140088791, | |||
20150117713, | |||
EP1087605, | |||
GB2421653, | |||
JP2002140362, | |||
JP2002304408, | |||
JP2003044503, | |||
KR100650389, | |||
KR20050072555, | |||
KR20060006271, | |||
RE38724, | Feb 01 1991 | Method and apparatus for providing shortest elapsed time route and tracking information to users | |
WO2006097907, | |||
WO2007087615, | |||
WO2007145625, | |||
WO2009053411, | |||
WO2010062726, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 16 2015 | Microsoft Technology Licensing, LLC | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Date | Maintenance Schedule |
May 24 2019 | 4 years fee payment window open |
Nov 24 2019 | 6 months grace period start (w surcharge) |
May 24 2020 | patent expiry (for year 4) |
May 24 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 24 2023 | 8 years fee payment window open |
Nov 24 2023 | 6 months grace period start (w surcharge) |
May 24 2024 | patent expiry (for year 8) |
May 24 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 24 2027 | 12 years fee payment window open |
Nov 24 2027 | 6 months grace period start (w surcharge) |
May 24 2028 | patent expiry (for year 12) |
May 24 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |