Searching and route mapping based on a social network, location, and time
A device, system, and method are directed towards providing location information from a social network. A GPS coordinate and a search criterion are received from a client device associated with a member of a social network. The social network is searched for another member associated with a location name based on the GPS coordinate and the search criterion. The location name may be a sponsored advertisement. The location name is provided to the client device. A communication may be enabled between the member and the other member. Moreover, a start and end location may also be received. The GPS coordinate and/or search criterion may be associated with either the start or end location. The searched location name is used to determine a location of interest. A route is determined between the start and end location and through the location of interest. The route is provided to the client device.
Latest Yahoo Patents:
- System and method for summarizing a multimedia content item
- Local content exchange for mobile devices via mediated inter-application communication
- Audience feedback for large streaming events
- Identifying fraudulent requests for content
- Method and system for tracking events in distributed high-throughput applications
The present invention relates generally to mobile communications and, more particularly, but not exclusively to providing geographical location description to a mobile client based in part on a social network.
BACKGROUNDTremendous changes have been occurring in the Internet that influence our everyday lives. For example, online social networks have become the new meeting grounds. They have been called the new power lunch tables and new golf courses for business life in the U.S. Moreover, many people are using such online social networks to reconnect themselves to their friends, their neighborhood, their community, and to otherwise stay in touch.
The development of such online social networks touch countless aspects of our everyday lives, providing instant access to people of similar mindsets, enabling us to form partnerships with more people in more ways than ever before, and providing relevant information to people within our social networks.
Global Positioning System (GPS) technology has improved our ability to detect precise geographical locations. GPS integration into mobile devices enables mobile detection of these locations. However, while GPS technology may provide accurate coordinates, they do not always provide accurate names for the coordinates or provide relevant information about the locations. In particular, location data can be inaccurate, especially down to the street address level. Thus, it is with respect to these considerations and others that the present invention has been made.
Non-limiting and non-exhaustive embodiments of the present invention are described with reference to the following drawings. In the drawings, like reference numerals refer to like parts throughout the various figures unless otherwise specified.
For a better understanding of the present invention, reference will be made to the following Detailed Description of the Embodiments, which is to be read in association with the accompanying drawings, wherein:
The present invention now will be described more fully hereinafter with reference to the accompanying drawings, which form a part hereof, and which show, by way of illustration, specific exemplary embodiments by which the invention may be practiced. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Among other things, the present invention may be embodied as methods or devices. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. The following detailed description is, therefore, not to be taken in a limiting sense.
Throughout the specification and claims, the following terms take the meanings explicitly associated herein, unless the context clearly dictates otherwise. The phrase “in one embodiment” as used herein does not necessarily refer to the same embodiment, though it may. Furthermore, the phrase “in another embodiment” as used herein does not necessarily refer to a different embodiment, although it may. Thus, as described below, various embodiments of the invention may be readily combined, without departing from the scope or spirit of the invention.
In addition, as used herein, the term “or” is an inclusive “or” operator, and is equivalent to the term “and/or,” unless the context clearly dictates otherwise. The term “based on” is not exclusive and allows for being based on additional factors not described, unless the context clearly dictates otherwise. In addition, throughout the specification, the meaning of “a,” “an,” and “the” include plural references. The meaning of “in” includes “in” and “on.”
As used herein, the term “social network” refers to a concept that an individual's personal network of friends, family colleagues, coworkers, and the subsequent connections within those networks, can be utilized to find more relevant connections for a variety of activities, including, but not limited to dating, job networking, service referrals, activity partners, or the like.
A social network typically comprises a person's set of direct and/or indirect personal relationships. Direct personal relationships usually include relationships with family members, friends, colleagues, coworkers, and other people with which the person has had some form of direct contact, such as contact in person, by telephone, by email, by instant message, by letter, or the like. These direct personal relationships are sometimes referred to as first-degree relationships. First-degree relationships can have varying degrees of closeness, trust, and other characteristics.
Indirect personal relationships typically include relationships through first-degree relationships to people with whom a person has not had some form of direct contact. For example, a friend of a friend represents an indirect personal relationship. A more extended, indirect relationship might be a friend of a friend of a friend. These indirect relationships are sometimes characterized by a degree of separation between the people. For instance, a friend of a friend can be characterized as two degrees of separation or a second-degree relationship. Similarly, a friend of a friend of a friend can be characterized as three degrees of separation or a third-degree relationship.
As used herein, the term “GPS coordinate” refers to any value based on a geographical coordinate system provided by a satellite-based radio positioning systems that provide physical positions, velocity and/or time information. The NAVSTAR system, operated by the U.S. Department of Defense, is an example of such a system. A GPS coordinate may include a longitude value, a latitude value, and/or an altitude value (e.g., referenced to a mean sea level). Geographical coordinate systems may express GPS coordinates in, for example, degree/minutes, degree/minutes/seconds, decimal degrees, or the like.
As used herein, the term “geographical coordinate” refers to any value based on a geographical coordinate system provided by lookup mechanism, triangulation mechanism, or by any other location identification system. Lookup mechanisms include IP address to geographical location mappings, MAC address to geographical location mappings, or the like. Triangulation mechanisms include WiFi triangulation, or any other wireless and/or radio triangulation.
As used herein, the term “location name” refers to any information identifying a geographical location. One or more location names may be associated with a GPS coordinate or a range or GPS coordinates. The term “location description” refers to any information about a geographical location, including a tag, comment, remark, or rating about the geographical location, a time relevant to the geographical location, or the like. One or more location descriptions may be associated with a location name. The term “location information” refers to a location name, location description or any other information associated with a location. Location information, a location name, and a location description may be any data, including a word, a set or words, a photograph, a sound bite, video footage, or the like.
As used herein, the term “within a proximity to” refers to two locations being near each other, wherein a measure of nearness may be a relatively small distance based on the scale of the measurement. Thus, for a large scale such as for distances between cities, the measure of nearness may be larger, but for a street level or the like, the measure may be smaller. The measure of nearness may be determined by any geometric measure, including a direct line between the locations, a Manhattan distance between the locations, or even determined by a user, or the like. In another embodiment, “a proximity to” is a predetermined value based on a scaling display value.
As used herein, the term “point” refers to a representation of a geographical location in a text, graphical, audio, or any other media object.
As used herein, the term “relevancy score” refers to information that represents whether a location name is a relevant name, or a commonly used name for a GPS coordinate with respect to a member and/or a community of a social network.
Briefly stated the present invention is directed towards updating location information for the social network and/or to providing the location information from the social network. A GPS coordinate and a search criterion are received from a client device associated with a member of the social network. The social network is searched for another member associated with a location name based on the GPS coordinate and the search criterion. The location name may be a sponsored advertisement. The location name is provided to the client device. A communication may be enabled between the member and the other member.
Moreover, a start location and end location may also be received. The GPS coordinate and/or search criterion may be associated with either the start location or the end location. The searched location name is used to determine a location of interest. A route is determined between the start location and the end location and through the location of interest. The route is provided to the client device.
Additionally, in another aspect of the invention, a request for the location information associated with a GPS coordinate is received from a client device associated with a member of the social network. In response to the request, a location name associated with another member of the social network is provided to the client device based on the GPS coordinate. Another location name may be received from the client device. The other location name may be associated with the GPS coordinate and with the member in the social network. Thus, the GPS coordinate and/or member may be associated with a plurality of location names. A location description may also be received and associated with the location name and with the member in the social network.
Although some methods, system, apparatuses, user interfaces, and data models of some embodiments of the present invention are described below as operating on GPS coordinates, in an alternate embodiment, these methods, system, apparatuses, use interfaces, and data models can be modified to operate substantially similarly on any other mechanism employable to obtain geographical coordinates, without departing from the scope of the invention.
Illustrative Operating Environment
One embodiment of mobile devices 102-103 is described in more detail below in conjunction with
A web-enabled mobile device may include a browser application that is configured to receive and to send web pages, web-based messages, and the like. The browser application may be configured to receive and display graphics, text, multimedia, and the like, employing virtually any web based language, including a wireless application protocol messages (WAP), and the like. In one embodiment, the browser application is enabled to employ Handheld Device Markup Language (HDML), Wireless Markup Language (WML), WMLScript, JavaScript, Standard Generalized Markup Language (SGML), HyperText Markup Language (HTML), extensible Markup Language (XML), and the like, to display and send a message.
Mobile devices 102-103 also may include at least one other client application that is configured to receive content from another computing device. The client application may include a capability to provide and receive textual content, multimedia information, and the like. The client application may further provide information that identifies itself, including a type, capability, name, and the like. In one embodiment, mobile devices 102-103 may uniquely identify themselves through any of a variety of mechanisms, including a phone number, Mobile Identification Number (MIN), an electronic serial number (ESN), or other mobile device identifier. The information may also indicate a content format that the mobile device is enabled to employ. Such information may be provided in a message, or the like, sent to GSS 106, client device 101, or other computing devices.
Mobile devices 102-103 may also be configured to communicate a message, such as through Short Message Service (SMS), Multimedia Message Service (MMS), instant messaging (IM), internet relay chat (IRC), Mardam-Bey's IRC (mIRC), Jabber, and the like, between another computing device, such as GSS 106, client device 101, or the like. However, the present invention is not limited to these message protocols, and virtually any other message protocol may be employed.
Mobile devices 102-103 may be further configured to enable a user to participate in communications sessions, such as IM sessions. As such, mobile devices 102-103 may include a client application that is configured to manage various actions on behalf of the client device. For example, the client application may enable a user to interact with the browser application, email application, IM applications, SMS application, and the like.
Mobile devices 102-103 may further be configured to include a client application that enables the end-user to log into an end-user account that may be managed by another computing device, such as GSS 106. Such end-user account, for example, may be configured to enable the end-user to receive emails, send/receive IM messages, SMS messages, access selected web pages, participate in a social networking activity, or the like. Participation in various social networking activities may also be performed with or without logging into the end-user account.
Mobile devices 102-103 may also communicate with non-mobile client devices, such as client device 101, or the like. In one embodiment, such communications may include participation in social networking activities, including sharing of multimedia information, sharing location information, or the like.
Client device 101 may include virtually any computing device capable of communicating over a network to send and receive information, including social networking information, or the like. The set of such devices may include devices that typically connect using a wired or wireless communications medium such as personal computers, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, or the like. Client device 101 may be configured to perform at least some of the same operations as mobile devices 102-103.
In addition, client devices 101-103 may include another application that is configured to search for location information based on a social network and/or a GPS coordinate(s). Client devices 101-103 may receive the GPS coordinate and/or search criteria from a user of client devices 101-103. Client devices 101-103 may enable the user to enter the GPS coordinate and/or search criteria with, for example, display 1100 of
Client devices 101-103 may retrieve the GPS coordinate(s) directly through a GPS interface on the client devices 101-103 or through a communication with another device, such as GPS source 105. For example, client device (mobile device) 102 may have an integrated GPS interface for retrieving GPS coordinate(s). Client device (mobile device) 102 may be a Nokia N95 handset with integrated GPS functionality. As shown, client device (mobile device) 103 has a GPS interface configured to communicate with external GPS source 105.
GPS source 105 may include virtually any computing device capable of receiving a GPS coordinate wirelessly, over a network, or the like. GPS source 105 may receive the GPS coordinate from one or more GPS enabled satellites. As shown, mobile device 103 is in communication with GPS source 105. The communication may include a wireless communication, such as Bluetooth, WiFi, IR, or the like. In one embodiment, GPS source 105 may be physically coupled to mobile device 103, via a USB port, serial port, or the like. In any case, the GPS coordinate is sent from GPS source 105 to mobile device 103 for further processing.
Wireless network 110 is configured to couple mobile devices 102-103 and its components with network 145. Wireless network 110 may include any of a variety of wireless sub-networks that may further overlay stand-alone ad-hoc networks, and the like, to provide an infrastructure-oriented connection for mobile devices 102-103. Such sub-networks may include mesh networks, Wireless LAN (WLAN) networks, cellular networks, and the like.
Wireless network 110 may further include an autonomous system of terminals, gateways, routers, and the like connected by wireless radio links, and the like. These connectors may be configured to move freely and randomly and organize themselves arbitrarily, such that the topology of Wireless network 110 may change rapidly.
Wireless network 110 may further employ a plurality of access technologies including 2nd (2G), 3rd (3G) generation radio access for cellular systems, WLAN, Wireless Router (WR) mesh, and the like. Access technologies such as 2G, 3G, and future access networks may enable wide area coverage for mobile devices, such as mobile devices 102-103 with various degrees of mobility. For example, Wireless network 110 may enable a radio connection through a radio network access such as Global System for Mobile communication (GSM), General Packet Radio Services (GPRS), Enhanced Data GSM Environment (EDGE), Wideband Code Division Multiple Access (WCDMA), and the like. In essence, Wireless network 110 may include virtually any wireless communication mechanism by which information may travel between mobile device s 102-103 and another computing device, network, and the like.
Network 145 is configured to couple at least some components of system 100 with each other, including, GSS 106, GLT server 134, rating and review server 133, messenger server 132, and sponsored search/ad server 131, client device 101, and through Wireless network 110 to mobile devices 102-103. Network 145 is enabled to employ any form of computer readable media for communicating information from one electronic device to another. Also, Network 145 can include the Internet in addition to local area networks (LANs), wide area networks (WANs), direct connections, such as through a universal serial bus (USB) port, other forms of computer-readable media, or any combination thereof. On an interconnected set of LANs, including those based on differing architectures and protocols, a router acts as a link between LANs, enabling messages to be sent from one to another. Also, communication links within LANs typically include twisted wire pair or coaxial cable, while communication links between networks may utilize analog telephone lines, full or fractional dedicated digital lines including T1, T2, T3, and T4, Integrated Services Digital Networks (ISDNs), Digital Subscriber Lines (DSLs), wireless links including satellite links, or other communications links known to those skilled in the art. Furthermore, remote computers and other related electronic devices could be remotely connected to either LANs or WANs via a modem and temporary telephone link. In essence, Network 145 includes any communication method by which information may travel between GSS 106, client devices 101-103, and other computing devices.
Additionally, communication media typically embodies computer-readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave, data signal, or other transport mechanism and includes any information delivery media. The terms “modulated data signal,” and “carrier-wave signal” includes a signal that has one or more of its characteristics set or changed in such a manner as to encode information, instructions, data, and the like, in the signal. By way of example, communication media includes wired media such as twisted pair, coaxial cable, fiber optics, wave guides, and other wired media and wireless media such as acoustic, RF, infrared, and other wireless media.
Devices that may operate as GSS 106, GLT server 134, rating and review server 133, messenger server 132, and sponsored search/ad server 131 include personal computers desktop computers, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, servers, and the like. GSS 106, GLT server 134, rating and review server 133, messenger server 132, and sponsored search/ad server 131 may use signal flows 800 and 900 of
One embodiment of GSS 106 is described in more detail below in conjunction with
Additionally, GSS 106 may also enable users of client devices 101-103 to enter/update the location description. GSS 106 may also manage the social network. In one embodiment, GLT server 134 may enable the members to define their communities (e.g., by adding members to the community, by defining a maximum size of the community, a maximum degree of separation between members of the community, or the like).
Moreover, GSS 106 may use services provided by GLT server 134, rating and review server 133, messenger server 132, and/or sponsored search/ad server 131 to perform at least some of its operations. For example, GSS 106 may request a rating/review of a location from rating and review server 133. GSS 106 may enable a communication between members of the social network by routing communications through messenger server 132. GSS 106 may receive sponsored advertisements for a GPS coordinate from sponsored search/ad server 131.
GSS 106 may also identify the geographical location of each one of client devices 101-103 via GPS coordinates sent from client devices 101-103, IP addresses, MAC addresses, or the like of client devices 101-103, or a user entered geographical location. GSS 106 may use the geographical location(s) to determine whether two or more of client devices 101-103 are within a proximity to each other. Devices determined to be within a proximity to each other are enabled to communicate with each other via messenger server 132, or the like. GSS 106 may use at least some steps of processes 400, 500, 600, and 700 of
GLT server 134 is configured to associate a GPS coordinate(s) with location information. In one embodiment, GLT server 134 may enable members of a social network to search, retrieve, and update/enter location information. In one embodiment, GLT server 134 may associate the location information with the GPS coordinate(s) and with the members in a social network data structure, in a database, or the like. One example of a social network data structure managed by GLT server 134 is social network 1400 of
Rating and review server 133 is configured to manage rating and/or reviews associated with a geographical location. Rating and review server 133 may enable GSS 106 to send a rating/review for the geographical location to update the rating/review, over network 145, or the like. Rating and review server 133 may enable GSS 106 to send a request to retrieve the rating/review for the geographical location.
Messenger server 132 is configured to relay messages between two or more of client devices 101-103. Messenger server 132 may relay IM, SMS, email, and/or VOIP messages, or otherwise enable a communication between two or more of client devices 101-103. In one embodiment, messenger serve 132 may forward a message between the two or more of client devices 101-103. In one embodiment, messenger server 132 may enable an initiation of the communication, and subsequently client devices 101-103 may communicate messages directly with each other. For example, messenger server 132 may send phone numbers of two or more of client device 101-103 to client device 101-103 to enable the users of client devices 101-103 to call each other. Messenger server 132 may use at least some steps of process 700 of
Sponsored search/ad server 131 is configured to receive payment from a sponsor for enabling storing, searching and providing of sponsored search results. The sponsored search results may location information. In one embodiment, the sponsor may be a member of the social network. Sponsored search/ad server 131 may be configured to associate one or more key words with a search result, geographical location, GPS location, location name, or the like. Sponsored search/ad server 131 may manage user accounts of sponsors, track the effectiveness of the sponsored search results, or the like. Sponsored search/ad server 131 may also be configured to provide to GSS 106, over network 145, the sponsored search results/ads in response to the one or more keywords. For example, in one embodiment, the key words may be part of a search criteria submitted by a user of one of client devices 101-103. GSS 106 may search for the key words through the user's social network, or may request sponsored search/ad server 131, over network 145, to return a sponsored search result/ad associated with the keywords. A plurality of search results provided to one of client devices 101-103 may be a combination of the sponsored search results and other search results. Sponsored search/ad server 131 may use at least some steps of processes 400 of
Although
Similarly, although GSS 106 is shown as a single computing device, the invention is not so limited. For example, one or more functions of GSS 106 may be distributed across one or more distinct computing devices. For example, managing various social networking activities, including adding members to a social network, sharing of information with members of the social network, managing Instant Messaging (IM) session, SMS messages, email messages, sharing of contact information, aggregating and/or storing of social networking information, or the like, may be performed by a plurality of computing devices, without departing from the scope or spirit of the present invention.
Illustrative Client Environment
Client device 200 also includes a power supply 226, one or more network interfaces 250, an audio interface 252, a display 254, a keypad 256, an illuminator 258, an input/output interface 260, a haptic interface 262, and a global positioning systems (GPS) interface 264. Power supply 226 provides power to client device 200. A rechargeable or non-rechargeable battery may be used to provide power. The power may also be provided by an external power source, such as an AC adapter or a powered docking cradle that supplements and/or recharges a battery.
Client device 200 may optionally communicate with a base station (not shown), or directly with another computing device. Network interface 250 includes circuitry for coupling client device 200 to one or more networks, and is constructed for use with one or more communication protocols and technologies including, but not limited to, global system for mobile communication (GSM), code division multiple access (CDMA), time division multiple access (TDMA), user datagram protocol (UDP), transmission control protocol/Internet protocol (TCP/IP), SMS, general packet radio service (GPRS), WAP, ultra wide band (UWB), IEEE 802.16 Worldwide Interoperability for Microwave Access (WiMax), SIP/RTP, and the like.
Audio interface 252 is arranged to produce and receive audio signals such as the sound of a human voice, music, or the like. For example, audio interface 252 may be coupled to a speaker and microphone (not shown) to enable telecommunication with others and/or generate an audio acknowledgement for some action. Display 254 may be a liquid crystal display (LCD), gas plasma, light emitting diode (LED), or any other type of display used with a computing device. Display 254 may also include a touch sensitive screen arranged to receive input from an object such as a stylus or a digit from a human hand.
Client device 200 may further include additional mass storage facilities such as CD-ROM/DVD-ROM drive 228 and hard disk drive 227. Hard disk drive 227 is utilized by client device 200 to store, among other things, application programs, databases, and the like. Additionally, CD-ROM/DVD-ROM drive 228 and hard disk drive 227 may store cookies, data, images, or the like.
Keypad 256 may comprise any input device arranged to receive input from a user (e.g., a sender). For example, keypad 256 may include a push button numeric dial, or a keyboard. Keypad 256 may also include command buttons that are associated with selecting and sending images. Illuminator 258 may provide a status indication and/or provide light. Illuminator 258 may remain active for specific periods of time or in response to events. For example, when illuminator 258 is active, it may backlight the buttons on keypad 256 and stay on while the client device is powered. Also, illuminator 258 may backlight these buttons in various patterns when particular actions are performed, such as dialing another client device. Illuminator 258 may also cause light sources positioned within a transparent or translucent case of the client device to illuminate in response to actions.
Client device 200 also comprises input/output interface 260 for communicating with external devices, such as a headset, or other input or output devices not shown in
In one embodiment, GPS interface 264 may be a GPS transceiver for receiving a GPS coordinate(s). Thus, GPS interface 264 can determine the physical coordinates of client device 200 on the surface of the Earth. GPS interface 264 can also employ other geo-positioning mechanisms, including, but not limited to, (WiFi) triangulation, Assisted GPS (AGPS), Enhanced Observed Time Difference (E-OTD), Cell Identity (CI), Service Area Identity (SAI), ETA, BSS and the like, to further determine the physical location of client device 200 on the surface of the Earth. In an alternate embodiment, GPS interface 264 may be configured to provide geographical coordinate(s) besides GPS coordinate(s), for example, coordinates provided by WiFi triangulation or the like. It is understood that under different conditions, GPS interface 264 can determine a physical location within millimeters for client device 200; and in other cases, the determined physical location may be less precise, such as within a meter or significantly greater distances.
In an alternate embodiment, GPS interface 264 may be a Bluetooth transceiver for receiving a GPS coordinate(s) from another device. The other device may be a GPS source, such as GPS source 105 of
Mass memory 230 includes a RAM 232, a ROM 234, and other storage means. Mass memory 230 illustrates another example of computer storage media for storage of information such as computer readable instructions, data structures, program modules or other data. Mass memory 230 stores a basic input/output system (“BIOS”) 240 for controlling low-level operation of client device 200. The mass memory also stores an operating system 241 for controlling the operation of client device 200. It will be appreciated that this component may include a general purpose operating system such as a version of UNIX, or LINUX™, or a specialized client communication operating system such as Windows Mobile™, or the Symbian® operating system. The operating system may include an interface with a Java virtual machine module that enables control of hardware components and/or operating system operations via Java application programs.
Client device 200 may also be configured to manage activities and data for one user distinct from activities and data for another user of client device 200. For example, in one embodiment, operating system 241 may be configured to manage multiple user accounts. For example, client device 200 may employ an operating system that is configured to request a user to provide account information, such as a user name/password, smart card, s/key, or the like. When the user logs into the associated account, operating system 241 may then manage data, activities, and the like, for the user separate from at least some of the data, activities, and the like, for another user. Thus, in one embodiment, operating system 241 may be configured to store client device data, cookies, social networking data, location information data, or the like, based on a client device account. Moreover, settings, configurations, or the like, of browser 246, messenger 272, or the like, may be based on the user account. Thus, when user A is logged into their client user account, browser 246 may receive, store, and/or retrieve cookies for user A, distinct from cookies associated with another user account on client device 200.
Memory 230 further includes one or more data storage 242, which can be utilized by client device 200 to store, among other things, programs 244 and/or other data. For example, data storage 242 may also be employed to store information that describes various capabilities of client device 200. The information may then be provided to another device based on any of a variety of events, including being sent as part of a header during a communication, sent upon request, and the like. Moreover data storage 242 may be used to store information such as data received over a network from another computing device, data output by a client application on client device 200, data input by a user of client device 200, or the like. For example, data storage 242 may include data, including cookies, and/or other client device data sent by a network device. Data storage 242 may also include image files, social networking data, location information data, or the like, for display and/or use through various applications. Moreover, although data storage 242 is illustrated within memory 230, data storage 242 may also reside within other storage mediums, including, but not limited to CD-ROM/DVD-ROM drive 228, hard disk drive 227, or the like.
Programs 244 may also include computer executable instructions which, when executed by client device 200, transmit, receive, and/or otherwise process messages and enable telecommunication with another user of another client device. Other examples of application programs include calendars, contact managers, task managers, transcoders, database programs, word processing programs, spreadsheet programs, games, CODEC programs, and so forth. In addition, mass memory 230 stores browser 246, and messenger 272.
Browser 246 may be configured to receive and to send web pages, forms, web-based messages, and the like. Browser 246 may, for example, receive and display (and/or play) graphics, text, multimedia, audio data, and the like, employing virtually any web based language, including, but not limited to Standard Generalized Markup Language (SGML), such as HyperText Markup Language (HTML), a wireless application protocol (WAP), a Handheld Device Markup Language (HDML), such as Wireless Markup Language (WML), WMLScript, JavaScript, and the like. Browser 246 may also be configured to receive, store, and/or provide data. For example, in one embodiment, browser 246 may receive and store client device data in the form of a cookie, or the like.
Messenger 272 may be configured to initiate and manage a messaging session using any of a variety of messaging communications including, but not limited to email, Short Message Service (SMS), Instant Message (IM), Multimedia Message Service (MMS), internet relay chat (IRC), mIRC, and the like. For example, in one embodiment, messenger 272 may be configured as an IM application, such as AOL Instant Messenger, Yahoo! Messenger, .NET Messenger Server, ICQ, or the like. In another embodiment, messenger 272 may be a client application that is configured to integrate and employ a variety of messaging protocols.
Location manager 280 may be configured to enable a user of client device 200 to search for location information based on the user's membership in a social network, a GPS coordinate associated with client device 200 and/or other search criteria. LM 280 may communicate with a geo-location search server such as GSS 106 of
Moreover, LM 280 may be configured to enable a user to enter/update location information associated with a GPS coordinate associated with the user in the social network. LM 280 may use display 1000 of
Alert manager 282 may be configured to automatically receive search result(s) based on the user's membership in a social network, a GPS coordinate associated with client device 200 and/or search criteria. Alert manager 282 may receive a push of the search result(s) over network interface 250, or the like. Alert manager 282 may be configured by user preferences to receive, block or ignore the pushed search result(s). Alert manager 282 may send the pushed search result(s) to LM 280 and/or browser 246, for display. As shown, alert manager 282 is optional, and at least some of the functionality of alert manager 282 may be provided directly through server side services (e.g., web pages) communicating with device 200 through browser 246 and/or network interface(s) 250.
Although LM 280 and alert manager 282 are described as operating on GPS coordinates, in an alternate embodiment, these components can be modified to operate substantially similarly with any geographical coordinates using any of a variety of other mechanisms without departing from the scope of the invention. For example, LM 280 may manage entry/update of geographical coordinates into the social network, and alert manager 282 may be configured to receive and provide the geographical coordinates.
Illustrative Server Environment
Network device 300 includes processing unit 312, video display adapter 314, and a mass memory, all in communication with each other via bus 322. The mass memory generally includes RAM 316, ROM 332, and one or more permanent mass storage devices, such as hard disk drive 328, tape drive, optical drive, and/or floppy disk drive. The mass memory stores operating system 320 for controlling the operation of network device 300. Any general-purpose operating system may be employed. Basic input/output system (“BIOS”) 318 is also provided for controlling the low-level operation of network device 300. As illustrated in
The mass memory as described above illustrates another type of computer-readable media, namely computer storage media. Computer storage media may include volatile, nonvolatile, removable, and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. Examples of computer storage media include RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, 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 a computing device.
The mass memory also stores program code and data. One or more applications 350 are loaded into mass memory and run on operating system 320. Examples of application programs may include transcoders, schedulers, calendars, database programs, word processing programs, HTTP programs, customizable user interface programs, IPSec applications, encryption programs, security programs, VPN programs, SMS message servers, IM message servers, email servers, account management and so forth.
Location Information Service (LIS) 354 may include any component configured to search, provide, update, enter, or otherwise manage location information, including GPS coordinates and/or other location information associated with GPS coordinates and with members in the social network. LIS 354 may receive the location information over network interface 310, or the like. In one embodiment, LIS 354 may associate the location information with the GPS coordinate(s) and with the member in a social network data structure, such as social network 1400 of
LIS 354 may search through the social network or request Social Network Manager (SNM) 356 to search through the social network for members associated with the requested location information. In one embodiment, LIS 354 may manage the location information remotely over network interface 310, by communicating with a location information service, such as GLT server 133, rating and review server 133, and sponsored search/ad server 131 of
SNM 356 includes any component for managing a social network over a network. SNM 356 may be configured to create, update, search, or otherwise manage the social network over network interface unit 310. SNM 356 may employ a process such as described below in conjunction with
SNM 256 may store the social network in a datastore, including hard disk drive 328, or the like. One embodiment of a representation of a social network is described in more detail in conjunction with social network 1400 of
The social network may also have characteristics, such as a size of a community for a particular member. The community of a member may be defined as a set of other members within a degree of separation from the member, a set of other members having a particular strength of association with the member, a maximum number of members in the community, or the like. Referring briefly to social network 1400 of
The social network of members may be searched for location information related to the members by a depth-first search, breadth first search, A* search, or any type of search algorithm for a graph and/or tree structure. Referring briefly to social network 1400 of
An A* search may be similar to the depth-first search, except that the stopping condition may be based on a heuristic, such as a strength of relatedness of the next member to be searched, an amount or last update of activity of the next member to be searched, or the like. In this manner, the search may focus on members with high relatedness to each other.
A breadth first search may begin at member 1401, continue to member 1402, and then continue to another member at a same degree of separation, e.g., member 1403, then continue to members of the next degree of separation, e.g., member 1404, and so forth, until a stopping condition occurs.
Although shown as a graph structure in social network 1400, the social network need not be stored in a graph structure. For example, referring briefly to table 1500 of
SELECT*FROM Table_1500 WHERE GPS_COORDINATE_X>(a−(search distance/X)) AND GPS_COORDINATE_X<(a+(search distance/X)) AND GPS_COORDINATE_Y>(b−(search distance/X)) and GPS_COORDINATE_Y<(b+(search distance/X)) AND MEMBER_ID IN (1401, 1402, 1403)
In this example, GPS_COORDINATE_X may represent a longitude value, and GPS_COORDINATE_Y may represent a latitude value. The “proximity to” measure is based on the parameter “search_distance,” given that a 1 degree change in latitude (or longitude) is equal to X meters (e.g. 1 meter=1/x degree change). Thus, the above statement finds location information associated with GPS coordinate(s) within a “search_distance” to (a,b).
In general, it will be clear to one in the art how to readily modify the above SQL statement to find for any GPS coordinate(s) (x1, y1), another GPS coordinate(s) (x2, y2), such that a distance d between (x1, y1) and (x2, y2) is less than or equal to “search_distance.” The distance d between (x1, y1) and (x2, y2) may be given by the formula:
d=√{square root over ((x2−x1)2+(y2−y1)2)}{square root over ((x2−x1)2+(y2−y1)2)}
Other formulas may also be used to take into account the curvature of the Earth, such as the Haversine formula, or the like. Briefly, the Haversine formula operates as follows:
R=Earth's radius (mean radius=6,371 km)
Δlat=y2−y1
Δlong=x2−x1
a=sin2(Δlat/2)+cos(lat1)*cos(lat2)*sin2(Δlong/2)
c=2*a tan 2(√a,√(l−a))
d=R*c
Thus, it will be clear to one in the art how to modify the above SQL statement to find, for any GPS coordinate(s) (x1, y1), another GPS coordinate(s) (x2, y2), such that a distance d between (x1, y1) and (x2, y2) is less than or equal to “search_distance,” while taking into account the curvature of the Earth.
Referring back to network device 300, Route Mapper (RM) 357 may include any component for mapping a route from one geographical location to another. RM 357 may access a street map, or other topological map, stored in a datastore, including hard disk drive 328, or the like. Given a start location and an end location, RM 357 may find a route between the locations using any route mapping algorithm, including the Moore algorithm, a shortest path algorithm, lowest traffic time algorithm, Frank-Wolfe algorithm, Wardrop equilibrium algorithm, or the like. The use of these algorithms may also take into account finding a route through intermediate locations. In one embodiment, the start location, end location and/or intermediate locations may be identified by GPS coordinates. RM 357 may request from LIS 354, at least some location description, such as location names associated with a GPS coordinate of a location in the route, or the like. RM 357 may employ a process such as described below in conjunction with
Messenger service 352 includes any component for enabling a communication between a plurality of devices. Messenger service 352 may be configured to relay messages between two or more of client devices 101-103 of
Although LIS 354, SNM 356 and RM 357, are described as operating on GPS coordinates, in an alternate embodiment, these components can be modified to operate substantially similarly with any geographical coordinates using any of a variety of other mechanisms without departing from the scope of the invention. For example, LIS 354 may geographical coordinates, and SNM 356 may manage the geographical coordinates in the social network, and RM 357 may manage routes between and/or through at least some points associated with the geographical coordinates.
Generalized Operation
The operation of certain aspects of the invention will now be described with respect to
Process 400 of
Processing next continues to block 404, where the social network is searched for another member associated with a location name based on the GPS coordinate and/or the search criteria. The search of the social network may begin at the member. In one embodiment, the search may be a breadth-first search, depth-first search, A* search, or the like, from the member to other related members of the social network, as described above in conjunction with
In one embodiment, the other member is found if a previously stored GPS coordinate associated with the location name and with the other member is within a proximity to the GPS coordinate received from the client device. In one embodiment, the search distance defining the proximity may be provided in the search criteria. The location name and the GPS coordinate may be directly associated (linked in the social network) with the other member or may be associated with a community of the other member. Referring briefly to social network 1400, the search may begin with member 1401. If the GPS coordinate provided by the client device is within a proximity to GPS coordinate 1440, then member 1401 is found, and location names 1450-1451 are provided for further processing. Alternatively, if the GPS coordinate provided by the client device is within a proximity to GPS coordinate 1441, then location name 1452 associated with the community of member 1401 (and thus associated with member 1401) is provided for further processing.
In one embodiment, besides being based on the GPS coordinate received from the client device, the search may also be based on a local time. In this embodiment, the local time is determined based on the GPS coordinate and on a time of receiving the GPS coordinate and/or the search criteria. In one embodiment, the local time may be determined from a GPS coordinate based on a Universal Coordinate Time (UTC) or other global time measure, and taking into account the local time zone of the GPS coordinate. In another embodiment, the global time measure may be received from a GPS source (e.g., the source for the GPS coordinate). In another embodiment, the local time may be a day of the week, a day of the month, a holiday, or the like, based on the GPS determined local time. For example, a member A may have entered a location name “Restaurant” for a GPS coordinate at a local time of 17:00 when member A was at or near the restaurant. The local time is also associated with the location name, the GPS coordinate, and with the member A in the social network. If, member B searches for any location at or near the GPS coordinate and at time 17:30, then the location name “Restaurant” may be returned because the time 17:30 is within a range of time 17:00. In any case, if the local time is within a range of a time associated with the location name, then the location name is provided for further processing. The range may be determined by an administrator as a set of time values representing temporal closeness, by the searching member, or the like.
In an alternate embodiment, at block 404 of
Processing next continues to block 406, where each found location names is included as a search result in a plurality of search results. A search result may be a record, object, or any other data structure. In one embodiment, one or more location descriptions associated with the appropriate found location name may also be included in a search result. Location descriptions include a tag, remark, comment, local time, rating, the GPS coordinate, or the like. An example search result may include location name 1451 of social network 1400 of
In one embodiment, the plurality of search results may comprise a list, a two dimensional array of points (e.g., representations of locations) corresponding the GPS coordinates of the location names in the search result or the like. Display 1200 of
Processing next continues to decision block 408, where it is determined if a search result (record) in the plurality of search results is a sponsored advertisement. A sponsored advertisement includes any location information (e.g., included in a search result record) for which any member of the social network, or any third-party has paid for the location description to be included in the plurality of search results. In one embodiment, the other member/third-party may purchase an association between the location information and the GPS coordinate a set of search words, or the like. Thus, in one embodiment, a payment may be received from the other member for associating another GPS coordinate with the location name in the social network, wherein the other GPS coordinate is within a proximity to the GPS coordinate. If it is determined that the location information/search result is a sponsored advertisement, processing continues to block 410. Otherwise, processing continues to block 412.
At block 410, the search result (e.g., the location name or other location information associated with the search result) is indicated as a sponsored advertisement within the plurality of search results. In one embodiment, a field associated with the search result may be marked as a sponsored advertisement and/or the field may be used to display the search result as a sponsored advertisement. For example, display 1200 of
At block 412, the plurality of search results are filtered based on the search criteria received from the client device and/or based on information about the social network. In one embodiment, the search criteria may include a query string, a search distance, a search time, a rating level, a community filter for the social network, or a time of last update of the location information (e.g., information updated within a recent time period, e.g., last ‘N’ days). An example of search criteria may include a distance from ‘here’ (e.g., where I am currently located), tag (e.g., “great restaurant” or “cinema”), time (e.g., 1 hour from now), and rating (e.g., 4 stars), or the like. The “where I am” criterion and time information can be based on the GPS coordinates sent from the client device.
In any case, each one of the search criteria may be associated with a type of location information. Accordingly, based on the type of the location information (e.g., string type, time type, rating type, location type (GPS coordinate)), the appropriate search criterion is matched against the particular location information. If a search result in the plurality of search results fails to match at least one of the search criteria, then the search result is filtered out of the plurality of search results. In one embodiment, the search result may also be filtered out unless it matches all of the search criteria.
For a string-typed search criterion, the search criterion may match location information (e.g., location description or location name) in a particular search result if at least a portion of a string of the location information matches the search criterion. The match may be based on any string-based search techniques, such as a regular expression match, a partial string match, a fuzzy string match, information retrieval searching, latent semantic indexing, or the like. These string based search criterion may include a search query, a Boolean query, a search string, a word, a set of words, a time range, a rating range, or the like. Searching may also involve removing stop words, stemming of strings, performing an inverse index lookup of the word, performing a Boolean match, or the like. Referring briefly to
For non-string based criteria, an appropriate type-based matching may be performed (e.g., a matching of a time within a range of times, a matching of a rating within a range of ratings, or the like). For time-matching, the range may be determined by an administrator as a set of time values representing temporal closeness, by the searching member, or the like. Referring briefly to
In one embodiment, the search criteria may include a community filter for the social network, and accordingly, filtering may be based on this information about the social network. The community filter may be a degree of separation between members of the social network, or any other information about a community of the member. The community of a member may be defined by for example, an administrator, the member, or the like, in a variety of ways. The community of a member may be defined as a set of other members within a degree of separation of the member, a set of other members having strength of association with the member, a maximum number of members in the community, or the like. In one embodiment, a search result associated with members who are outside the community may be filtered out. Referring briefly to
In another embodiment, a first member with a same or lower degree of separation than the degree of separation defined in a community filter may be selected to remain in the search result, while other members with a higher degree of separation may be filtered out. Referring briefly to
Referring back to process 400, processing next continues to block 414, where the search results are ordered based on relevancy information of a search result included in the plurality of search results. In one embodiment, relevancy information may include a degree of separation between the member and the other members associated with search results, an amount of match of the search criteria, a relevancy score, a status of the search result (e.g., as a sponsored advertisement), an origin of the search result (e.g., from the social network or from a default database), a rating associated with the search result (e.g., where a location description in the search result is a rating), or virtually any other relevancy information.
In one embodiment, the search result with a greater amount of match may be ordered higher in the search results (e.g., ordered before another search result, indicated as larger on a N dimensional map, or the like). Referring briefly to
In another embodiment, the relevancy information may include social network information. In this embodiment, a first search result associated with a first member of the social network may be ordered higher in the search results than a second search result associated with a second member, if the first member has a lower degree of separation from the member associated with the client device than the second member. Referring briefly to
In yet another embodiment, a relevancy score may be associated with at least one of location information in a search result. The relevancy score may be used (alone or in combination with other relevancy information) to order the search results. Referring briefly to
In an alternate embodiment, the ordering may be based on a combination of the relevancy information described above, or any other relevancy information. In one embodiment, the relevancy information may be the amount of match multiplied by an inverse of the degree of separation, or the like.
Processing next continues to block 416, where the search results are provided to the client device, a calling process, or another process or device. In one embodiment, the search result may be provided as a list (e.g., text, XML, or the like), an HTML page, an image, over a network, or the like. Display 1200 of
In one embodiment, the search results may be pushed to the client device (e.g., as an alert providing the search results, or the like). In another embodiment, the client device may pull (through a HTTP request, or the like), the search results (e.g., as a map that includes the location description of each of the search results). In one embodiment, the member associated with the client device may specify a preference for delivery of search results (e.g., as pushed or pulled search results). In one embodiment, the preference may specify a time of day (range) when the search results may be pushed/pulled, a geographical location (range) for which the search results may be pushed/pulled or the like. In one embodiment, the preference may even specify that sponsored advertisements may be blocked/filtered, from the member. In another embodiment, the preference may be based on an aggregate of preferences of members of a community. Processing then returns to calling process for further processing.
In an alternate embodiment, blocks 412 and 414 may be optional and might not be performed. In another alternate embodiment, blocks 404, 412, and/or 414 may occur concurrently. In this embodiment, appropriate location names and/or tags may be selected, filtered, and/or ordered while the social network is being searched for members associated with the location names. The plurality of search results may be modified based in part on a match of at least one search result of the plurality of search results with a search criteria received form the client device, and further based on relevancy information associated with the at least one search result.
Process 500 of
In another embodiment, only one of the start location or end location is received, and the other location is determined based on an identity of the member in the social network. For example, the other location may be based on interests of the member or community of the member. In this embodiment, the other location may be a frequently searched location, a highly rated location for the member/community, or the like. In one embodiment, the other location may be within a proximity to a GPS coordinate associated with the client device. A time associated with the other location may also be within a (close) range of a current local time associated with the client device, or the like. The other location may also be a sponsored advertisement. In an alternative embodiment, block 502 may be optional, and both the start location and end location may be determined based on an interest of the member or the community.
Processing next continues to block 504, where a GPS coordinate and/or search criteria associated with either the start location and/or end location is determined. In one embodiment, the GPS coordinate and/or the search criteria may be provided by the client device. Alternatively, the GPS coordinate may be retrieved from the social network—e.g., the GPS coordinate is associated with a location of interest of the member or the community of the member. In another embodiment, the GPS coordinate may be a point (e.g. a midway point) between a first GPS coordinate associated with the start location and an end GPS coordinate associated with the end location. Also in an alternate embodiment, the search criteria may be determined based on at least a part of a location description (e.g., a local time, a tag, or the like) associated with the start and/or end location. For example, the search criteria may include the query string “music” if the start and/or end location are associated with the location description “music store.” Accordingly, the search criteria and GPS coordinate may define a search of similar locations within a proximity to the particular location.
Processing next continues to block 506, where a plurality of search results including other locations (e.g., location information, location names, or the like) are received based on the GPS coordinate, a search criterion /criteria and/or information about the member associated with the client device. In one embodiment, the social network is searched for another member and a location of interest based on the GPS coordinate and the search criterion/criteria, wherein the location of interest has been identified, in the social network as relevant to the other member. In one embodiment, the searching may be performed by process 400 of
Processing next continues to block 508, where a search result/location included in the plurality of search results may be used to determine at least one location of interest. In one embodiment, the location of interest may include the start location or the end location (e.g., there are no other locations in the route between the start location and end location). In one embodiment, each search result of the plurality of search results may be a location of interest. In one embodiment, the geographically closest location may be determined to be the location of interest. In another embodiment, the search result ordered the highest in the plurality of search results may be determined as the location of interest.
Processing next continues to block 510, where a route is determined between the start location and the end location, and wherein the route includes at least one location of interest (e.g., the route is though the at least one location of interest). The route between the locations may be determined using any route mapping algorithm, including those discussed above.
Processing next continues to block 512, where the route is provided to the client device. In one embodiment, the route may be included in the search results and provided to the client device. For example, the route may be over-laid on an HTML, image, or other version of the search results, or the like. In another embodiment, the route may be included in a separate field in the search result. In any case, the modified search result including the route is provided to client device or another process or device. In one embodiment, the modified search results are pushed to or pulled from the client device substantially similar to the process described in block 416 of
As an example of process 500, a member searches for a route from A to B at or around 10 A.M., local time by, for example, sending entering a GPS coordinate associated with the member's client device as point A, and another GPS coordinate as point B. If the changing of the guards at Buckingham palace is near the route from A to B at or near 10 A.M, then the route presented may include the location of the changing of the guards as a location of interest along the path from A to B. If however the member is traveling at 12 A.M., and the changing of the guards does not happen at that time, then this location of interest may not be included in the route from A to B.
Process 600 of
Processing next continues to block 603, where the client device may be provided with a mechanism for updating and/or entering another location name associated with the GPS coordinate. In one embodiment, the mechanism may be an entry box for entering and/or updating the text of the location name. In another embodiment, the mechanism may provide a selection list of possible location names based on a history of location names entered at a location within a proximity to the GPS coordinate, and/or at a time within a (close) range to a local time associated with the GPS coordinate. The member may select one of the location names in the list.
Processing next continues to decision block 604, where it is determined if another location name associated with the GPS coordinate is received from the client device. Display 1000 of
At block 608, the other location name may be associated with the GPS coordinate and/or with the member in the social network. In another embodiment, instead of being associated with the GPS coordinate received from the client device, the other location name may be associated with another GPS coordinate originally associated with the location name provided in the search results at block 602. Alternately, the location name may be associated with an intermediate GPS coordinate between the received GPS coordinate and the other GPS coordinate.
In any case, the location name may be canonicalized (e.g., capitalized, stemmed, transcoded), or otherwise pre-processed to covert the location name into a standardized format. In one embodiment, if a previously stored location name associated with the GPS coordinate is substantially similar to the other location name (e.g., based on partial string match, removing stop words, stemming the words, or the like), the other location name may be changed to be previously stored location name. For example, given the other location name “The Best Restaurant” and the other previously stored location name “BEST RESTAURANT,” the other location name may be canonicalized into “BEST RESTAURANT.”
In one embodiment, at block 608, a local time (e.g., a type of location description) may also be associated with the other location name in the social network. The local time may be determined based on the GPS coordinate and on a time of receiving the other location name. In this embodiment, the current time of the server is translated into a local time of the client device based on a time zone associated with the GPS coordinate. For example, in social network 1400, location description 1471 may be a time at or near the time that location name 1451 was received from member 1401.
In any case, the other location name and/or determined local time are updated (e.g., associated with the member and the GPS coordinate) in the social network to enable further searching of the social network for the other location name, to enable another request for location information associated with the GPS coordinate to return at least the location name and the other location name, or the like. The other location name and/or determined local time may be updated in, for example, a social network data structure such as social network 1400 of
In one embodiment, a relevancy score may be updated for an association between the other location name and a GPS coordinate. The update may occur for the member and/or a community of the member. For example, in social network 1400 of
In any case, in one embodiment, the relevancy score for the association between the other location name and the GPS coordinate for the member may be increased based on a frequency of receiving the other location name, wherein the increased relevancy score is configured to be used in part to order search results of location names. Accordingly, as more members of a community associate a particular location name with the GPS coordinate, the relevancy score may become higher. The relevancy score may be used by process 400 of
Referring back to process 600, processing next continues to block 605, where the member may be provided with a mechanism for updating and/or entering tag, rating, comment, local time, or other location description associated with the (other) location name. In one embodiment, the mechanism may be an entry box for entering and/or updating the text of the location description (e.g., tag, rating, or the like). In another embodiment, the mechanism may provide a selection list of possible location description based on a history of location description entered at a location within a proximity to the GPS coordinate and/or at a time within a (close) range to a local time associated with the GPS coordinate. The member may select one of the location descriptions in the list. In one embodiment, the mechanism for entering the other location name of block 603 and the mechanism for entering the location description may be the same mechanism. Display 100 of
Processing next continues to decision block 606, where it is determined if the location description is received from the client device. In one embodiment, the location description and/or the other location name from block 602 may be received concurrently. If it is determined that the location description is received, then processing continues to block 610. Otherwise, processing continues to decision block 612.
At block 610, the location description may be associated with the original location name received as part of the search results of block 602 and/or with the other location name received from block 608. In one embodiment, the location description may be associated to enable another searching of the social network based on or using the location description, or the like. The location description may also be associated with the member or a community of the member in the social network. In one embodiment, the location name maybe canonicalized, substantially similar to the process of block 608. As an example, social network 1400 of
In one embodiment, the location description may be a local time determined locally by the client device (via an internal clock, or the like), and sent to a server for updating/entering. In an alternate embodiment, the other location description may be a comment. The comment may be about a location name entered by the member and may be sent to the other member. The comment may be sent to the other member over the other member's preferred mode of communication (e.g., IM, SMS, email, web-post, blogging, or the like).
Processing next continues to decision block 612, where it is determined whether more updating/entering of location names or location description is required. In one embodiment, the member, using the client device, may continue to request more search results. In another embodiment, other members, using other client devices, may request more search results. In any case, subsequent searches are refined to take into account the entered location name and location description. If it is determined that more updating is required, then processing loops back to block 602. Otherwise, processing returns to a calling process for further processing.
Although process 600 is described as associating location information (e.g., location name and location description) with the member, process 600 may be modified to associate the location information with other members, a community, or even all member of the social network, without departing from the scope of the invention. In one embodiment, the location information may be associated with the other member, e.g., an originating member who originally entered the location name provided in the search results at block 602. In another embodiment, the location information may be also associated with a community. The community may include both the member and the other member. For example, referring to
Process 700 of
Processing next continues to decision block 704, where it is determined if the member is within a proximity to the other member. In one embodiment, the GPS coordinate may be used to determine the geographical location of the member. In one embodiment, another GPS coordinate of the other member may be received from another client device of the other member. In yet another embodiment, a geographical location of the other member may be stored in a database, or other datastore, determined based on a MAC address or an IP address of a client device of the other member, or the like. In any case, based on a distance between the geographical location of the members, it is determined whether the members are within a proximity to each other. If the members are within a proximity to each other, then processing continues to block 708. Otherwise, processing returns to a calling process for further processing.
Processing next continues to decision block 708, where a communication is enabled between the member and the other member. In one embodiment, the communication may be based on the preference(s) of either or both the member and the other member. The preference(s) may include, a particular mode of communication, a geographical area or time of day to receive the information, a minimal degree of separation between the members before communication is enabled, a block list of members for whom no communication is allowed, whether communication should be enabled at all (e.g., a complete block of communication), or the like. The communication may be any form of communication, including an IM, SMS, email, web-post, blogging, or the like. In one embodiment, the members may also be enabled to provide their geographical locations to each other as part of the communication. In another embodiment, the geographical locations may be provided before the communication is enabled. In an alternate embodiment, the communication is enabled between the member and a plurality of other members (associated with search results) based on whether the other members are within a proximity to the member.
As one example of a use case of process 700, a member arrives in a city and performs a GPS coordinate search of the area that he/she is currently in. If there is another member currently active in the search area who has entered at least one of the search results of the search, the member can chat with the other member(s). Either member could opt-in to receive messages. The geographical location of the members can be hidden from each other, until after the chatting begins and/or the members decide to reveal their actual physical location to each other.
It will be understood that each block of the flowchart illustration, and combinations of blocks in the flowchart illustration, can be implemented by computer program instructions. These program instructions may be provided to a processor to produce a machine, such that the instructions, which execute on the processor, create means for implementing the actions specified in the flowchart block or blocks. The computer program instructions may be executed by a processor to cause a series of operational steps to be performed by the processor to produce a computer implemented process such that the instructions, which execute on the processor to provide steps for implementing the actions specified in the flowchart block or blocks. The computer program instructions may also cause at least some of the operational steps shown in the blocks of the flowchart to be performed in parallel. Moreover, some of the steps may also be performed across more than one processor, such as might arise in a multi-processor computer system. In addition, one or more blocks or combinations of blocks in the flowchart illustration may also be performed concurrently with other blocks or combinations of blocks, or even in a different sequence than illustrated without departing from the scope or spirit of the invention.
Accordingly, blocks of the flowchart illustration support combinations of means for performing the specified actions, combinations of steps for performing the specified actions and program instruction means for performing the specified actions. It will also be understood that each block of the flowchart illustration, and combinations of blocks in the flowchart illustration, can be implemented by special purpose hardware-based systems which perform the specified actions or steps, or combinations of special purpose hardware and computer instructions.
Illustrative Signal Flow
User 802 enters several search criteria, including a text to search for (e.g., matched against tags, location names, or any other text field associated with a GPS coordinate), a search distance, a search time, a rating filter, a community filter, or the like. The search distance may represent a distance from the current location of client device 104 (e.g., identified by a GPS coordinate(s) received from GPS source 105). A search time may default to a current local time if one is not entered. A community filter may default to user 802's community.
As shown, client device 104 retrieves a GPS coordinate(s) from GPS source 104. In another embodiment, the client device 104 may include a GPS receiver configured to retrieve the GPS coordinate(s) without communicating with GPS source 105. Client device 104 also submits the search criteria and the GPS coordinate(s) to Geo-location Search Server (GSS) 106 for further processing. In response, Client device 104 receives the search result(s) from GSS 106. Client device 104 displays the search result(s) on a display in an HTML enabled browser, in a proprietary display, or the like.
GPS source 105 may be a Bluetooth enabled GPS device configured to communicate one or more GPS coordinates with client device 104. GPS source 105 receives a request for a GPS coordinate(s) and returns the GPS coordinate(s) of where GPS source 105 is located. In one embodiment, GPS source 105 may be configured to return one ore more GPS coordinate(s) (e.g., a longitude, a latitude, a range of longitudes and latitudes near its current geographical location, or the like).
GSS 106 receives the search criteria and performs a search of a social network for a location name based on the GPS coordinate(s) and the search criteria. In one embodiment, if the location name is absent from the social network, a member in the social network associated with the location name is not found, or the search does not otherwise return a search result, GSS 106 may request from GLT Server 134 an address associated with the geographical coordinate, and may provide this address as the location name. The search process is described in more detail in process 400 of
Rating and review server 133 may receive a request for a rating for a location name and/or GPS coordinate. The request may be a search criteria (e.g., rating filter). Thus, rating and review server 133 may only return ratings that match the search criteria. In another embodiment, rating and review server 133 may return all ratings associated with the location name and/or GPS coordinate.
As shown, user 902 requests a location, via a search or other form of retrieval request. Client device 104 may respond to the request for the location, by, among other things, getting a GPS coordinate(s) from GPS source 105. The location may be specified as a single GPS coordinate, but may also be specified as a proximity or range of GPS coordinates (e.g., a 2 meter radius from the GPS coordinate). Although, signal flow 900 shows a GPS source 105 providing GPS coordinates to client device 104, signal flow 900 can be modified such that GPS source 105 is optional and unused, and the GPS coordinates may be retrieved directly from client device 104. In one embodiment, user 902 may perform a search of a social network similar to the process shown in signal flow 800 of
Client device 104 may request GLT server 134, for location names (e.g., named locations) based on the GPS coordinate(s). In one embodiment, GLT server 134 may respond with address details, and/or location names for the GPS coordinate(s). Based on members update, entry, or feedback there could be several location names for a GPS coordinate. In on embodiment, a street address may be provided as the primary location. In another embodiment, location name(s) provided by other members may be provided. Client device 104 may then display the retrieved location information.
In response, user 902 may be enabled by client device 104 to select one of the provided location names (e.g., names or address) for updating. User 902 may update the location name and/or other location description be entering the information into client device 104. The location description includes tags, ratings, photos, reviews, and/or other details about the location name. The location name and/or other location description are sent to GSS 106 for further processing.
GSS 106 may associate or send a request to GLT server 134 to associate the location name with the GPS coordinate and/or with user 902 in the social network. GSS 106 may also associate the location description with the location name and/or user 902 in the social network. GSS 106 may also send rating/review information received form client device 104 to rating and review server 133 for storage and further processing. Moreover, GSS 106 may submit/send the location name and GPS coordinate (e.g., the named GPS coordinate) to GLT server 134 for update/association in the social network or other database or datastore.
Although not shown, the update/association of the location name/location description enables GSS 106 to receive a another request for a plurality of location names to be found in the social network based on the received GPS coordinate. GSS 106 may provide, in response to the other request, at least the location name and the other location name in the plurality of location names, wherein the plurality of location names is ordered based on a comparison of a frequency of an update of the location name with another frequency of another update of the other location name.
Although signal flows 800 and 900, are described as operating on GPS coordinates, in an alternate embodiment, these signal flows can be modified to operate substantially similarly with any geographical coordinates using any of a variety of other mechanisms without departing from the scope of the invention. For example, in signal flows 800 and 900, client device 104 may retrieve a geographical coordinate from GPS source 104, and may send the geographical coordinate to GSS 106 for further processing.
Illustrative User Interfaces
In one embodiment, a member of the social network may use display 1000 of
As shown, GPS coordinate 1005 comprises two text entry boxes, pre-populated with GPS coordinates determined by the geographical location of the client device. The member may update GPS coordinate 1005.
Location pull-down list 1002 may display a location name currently associated with the GPS coordinate 1005. Location pull-down list 1002 may be a selection list of possible location names based on a history of location names entered at a location within a proximity to GPS coordinate 1005 and/or at a time within a (close) range to a local time associated with GPS coordinate 1005. In one embodiment, the selection list may be sorted based on the most recent location name entered and/or by a frequency of a particular location name chosen for GPS coordinate 1005. Accordingly, there can possibly be more than one address or location name for a particular location/GPS coordinate. Moreover, location entry 1004 may also enable the member to enter a different location name to be associated with GPS coordinate 1005 in the social network. As shown, the member has entered “Best Restaurant.”
Tag entry 1007 enables the member to enter a new tag, including a single tag or a set of tags (e.g., entered as a list of words with spaces in between). Tag list 1010 displays previously entered tags for the location name. In one embodiment, the tags in tag list 1010 may have been previously entered by, for example, member “John Smith,” or by any other member of the social network. By pressing button 1008, the member may associate the tag in tag entry 1007 or the tag selected from tag list 1010 if no tag is entered in tag entry 1007 with the location name.
Time 1011-1012 may be entered as hours and minutes, but may be specified as any time measure. Time 1011-1012 may be used by the member to specify a time associated with the GPS coordinate 1005 and a location name. Time 1011-1012 defaults to a current local time for GPS coordinate 1005.
Add media button 1020 may enable the member to associate a photo, sound bite or video footage, or other media with the location name (e.g., from location pull down list 1002 or from location entry 1004). In one embodiment, the media may be stored as a tag, or other location description.
Add rating and review button 1014 may enable the member to access another display that allows the member to associate a rating and review with the location name. A rating may be any numeric value, star rating, or other qualitative value.
Submit location button 1016 enables the member to submit the location name, or any of the location description from display 1000 for updating/entering in the social network.
Send comment button 1022 enables the member to send a comment via another display to another member associated with the location name. For example, the member may send a comment to the other member “John Smith” over a variety of modes of communications, including SMS, IM, email, telephone, or the like.
Add to community button 1024 enables the member to add the other member to the member's community/social network. In one embodiment, a link may be created between the member and the other member in the social network.
The search may be based in part on GPS coordinate 1107. As shown, GPS coordinate 1107 comprises two text entry box, pre-populated with GPS coordinates determined by the location of the client device. The member may update the GPS coordinate 1107.
The search may also be based on other search criteria, including a search string determined by search drop down list 1102 and/or query box 1104, proximity list 1106, time 1109-1110, and/or rating drop list 1112.
Search drop down list 1102 and/or query box 1104 enable the member to specify a search string to be matched against location names, tags, or other location description associated with members in the social network.
Time 1109-1110 may be entered as hours and minutes, but may be specified as any time measure. Time 1109-1110 may be used by the member to specify a time associated with the GPS coordinate and location name. Time 1011-1012 defaults to a current local time for the GPS coordinate 1107.
Proximity list 1106 enables the user to specify a proximity to search within—e.g. a distance from GPS coordinate 1107.
Submit button 1116 sends GPS coordinate 1107 and/or the search criteria specified on display 1100 to a server, for further searching of the social network. Process 400 of
Advanced search button 1114, when pressed, provides an advance search display (not shown) which enables the member to retrieve search results that are determined by other search criteria, including whether the searched location information is associated with a review, or a photo, or other form of media. In one embodiment, the advance search display enables the member to add a filter to only return locations that have been added within the past ‘X’ days.
As shown, the search results for a search of “Restaurants within 500 meters”, specified by label 1202, are shown in display 1200 of
The search results may be ordered, such that some points are more relevant to the user of display 1200/member, then other points. For example, point 1204 is larger (e.g., more relevant) than point 1208, and point 1207 is larger than point 1207. Location names may also be shown with the points (e.g., “Best restaurant” for point 1207). Moreover, a location description, such as a tag may also be shown (e.g., “drinks after work”). A location name/point determined to be a sponsored advertisement may be highlighted as such. For example, point 1205 may be displayed in a different color, and the term “Sponsor:” may be added to its location name. In general, any indication may be used to indicate the source of sponsorship, or that the point is a sponsored point. In one embodiment, the member may have opted-in or opted-out of receiving marketing messages (e.g., point 1205).
As shown, display 1200 also includes zoom bar 1230 configured to enable the user to zoom in on a specified are of the map. Chat button 1220 may enable the member to communicate with at least one other member associated with at least one of the points shown and who are within an immediate proximity.
Although not shown, if the member selects a point, a display which includes the details of the search result may be shown. The display may include the name of another member who entered the search result, a rating, a location name, one or more tags, or the like. The member may further select a more detailed display associated with the point. The detailed display may be similar to display 1000 of
Illustrative Data Models
As shown, social network 1400 may be a graph, but may be any other structure configured to store network information, including a tree, a database, a linked list, or the like.
Social network 1400 includes members 1401-1405. Members 1401-1405 maybe related to each other by one or more degrees of separation. For example, member 1401 is related to members 1402-1403 by one degree of separation. Member 1401 is related to member 1404 by two degrees of separation, and to member 1405 by three degrees of separation.
Community of member 1401 is shown as a boundary around members 1401-1403. Community of member 1401 may be determined by any mechanism for grouping members, including a maximum degree of separation between member 1401 and other members of the community, a maximum number of other members closely related to member 1401, a particular strength of association between member 1401 and the other members, or the like.
A detailed view of other objects related to member 1401 is also shown. The other objects may have been provided by member 1401, provided by other members of social network 1400, or even entered as a default setting, by for example, a system administrator, or the like. Process 600 of
Location name 1450 is associated with GPS coordinate 1440 and with member 1401 by a relevancy score of 0.5. Location name 1451 is associated with GPS coordinate 1440 and with member 1401 by a relevancy score of 0.8. Accordingly, location name 1451 is more closely related to GPS coordinate 1440 and with member 1401 than location name 1450.
Location descriptions 1470-1472 are associated with location name 1451. While location description 1470 is shown as a rating, location description 1471 is shown as a time, and location description 1472 is shown as a tag, location descriptions 1470-1472 may include any type of location description, including a comment, a review, multimedia, or the like.
GPS coordinate 1441, location name 1452, and location description 1472 are examples of information associated with all members of a community. GPS coordinate 1441 is associated with community for member 1401. GPS coordinate 1441 is associated with location name 1452. Location name 1452 is associated with location description 1472. In one embodiment, GPS coordinate 1441, location name 1452, and location description 1472 may be provided by an administrator, pre-loaded, or the like. In another embodiment, this information may be changed from information associated to a particular member to information associated with a community.
As shown, table 1500 includes records with fields for a record ID, GPS coordinate, member ID, location name, community, relevancy score, and time. These fields are shown as example, and other fields may be included, or some fields may be omitted without departing from the scope of the invention.
Record IDs 1561-1564 are unique IDs for identifying the rows. Values for Record IDs 1561-1564 may be unique, but may be assigned arbitrarily. GPS coordinates 1502-1509 include any type of GPS coordinates. As shown, GPS coordinates 1502-1509 are shown as being stored in a GPS coordinate X and GPS coordinate Y fields. The GPS coordinate X and GPS coordinate Y fields may, for example, represent longitude and latitude values, respectively. In another embodiment, the GPS coordinate X and GPS coordinate Y values may be stored in the same field. Member IDs 1512-1515 may be any identifier for members of a social network, including numeric identifiers. Location names 1522-1525 are shown as string values, but may be any type of media, including photos, video, or the like. Communities 1532-1535 are lists of members. Relevancy scores 1542-1545 may be any numeric or quantitative value configured to be used in ordering or ranking the location information of table 1500. Times 1552-1555 may be any time measure.
As shown, at least some records of table 1500 may include no values for some fields. These fields may match any value. For example, time 1552 may match any time. Similarly, the row identified by record ID 1452 may have no value for its member ID, and thus may represent a location record for a community.
Moreover, some rows may represent default location names for a GPS coordinate (e.g., a street address). For example, the row identified by record ID 1565 includes no values for member ID 1515, community 1535, relevancy score 1545, and time 1555. Thus, this row may include default data for GPS coordinates 1508-1509.
Location description types 1602-1604 may include any type for location descriptions, including a tag, a comment, a rating, a review, a time, or the like. Location descriptions 1622-1624 include the values for the location descriptions.
The above specification, examples, and data provide a complete description of the manufacture and use of the composition of the invention. Since many embodiments of the invention can be made without departing from the spirit and scope of the invention, the invention resides in the claims hereinafter appended.
Claims
1. A method for providing location description over a network, comprising:
- receiving, by a processor, from a client device associated with a member of a social network, a start location, an end location, a Geo Positioning System (GPS) coordinate and search criteria;
- searching, by the processor, the social network for another member associated with a location name that is relevant to the GPS coordinate and the search criteria;
- determining, by the processor, a location of interest based on the location name;
- ordering, by the processor, each search that provides a plurality of location name results based at least in part on a degree of separation between the member and the other members associated with the plurality of location name results; and
- providing, by the processor, the ordered plurality of location name results to the member associated with the client device and providing a route between the start location and the end location generated to include the location of interest.
2. The method of claim 1, wherein searching the social network further comprises:
- determining whether another GPS coordinate associated with the location name is within a proximity to the GPS coordinate.
3. The method of claim 1, wherein searching further comprises:
- determining a local time based on the GPS coordinate and on a time of receiving the GPS coordinate and the search criteria; and
- determining whether the local time is within a range of a time associated with the location name.
4. The method of claim 1, wherein searching the social network comprises;
- providing the location name and location description associated with the location name as part of a search result in a plurality of search results;
- filtering at least one search result from the plurality of search results if the at least one search result fails to match at least a part of the search criteria;
- ordering the plurality of search results based on at least one of a degree of separation between the member and the other member associated with the at least one search result, an amount of match of the search criteria, a relevancy score, a status of the at least one search result as a sponsored advertisement, an origin of the at least one search result, or a rating associated with the at least one search result.
5. The method of claim 1, further comprising:
- receiving from the other member a payment for associating another GPS coordinate with the location name in the social network, wherein the other GPS coordinate is within a proximity to the GPS coordinate; and
- indicating the location name as a sponsored advertisement in a plurality of search results.
6. The method of claim 1, wherein either the start location or the end location is associated with the GPS coordinate.
7. The method of claim 1, wherein the route between the start location and the end location is generated after the location of interest has been determined.
8. A method for providing location description over a network, comprising:
- receiving, by the processor, from a client device associated with a member of a social network, a start location and an end location;
- determining, by the processor, a GPS coordinate based on the start location or the end location;
- determining, by the processor, a search criterion based on a location description associated with the start location or the end location;
- searching, by the processor, the social network for at least one of a plurality of members and at least one of a plurality of locations of interest based on the GPS coordinate and the search criterion, wherein the at least one location of interest has been identified in the social network as relevant to another member, and wherein searching that provides a plurality of location of interest results that is ordered based at least in part on a degree of separation between the member and the at least one of the plurality of members; and
- determining, by the processor, a route between the start location and the end location and through the location of interest based at least on the ordered plurality of location of interest results; and
- providing, by the processor, the route to the client device.
9. The method of claim 8, wherein providing a location name associated with the GPS coordinate comprises pushing to the client device, the location name, or pulling by the client device, the location name.
10. The method of claim 8, wherein the search criterion includes a query string, a search distance, a search time, a rating level, a community filter for the social network, or a time of last update of the location name or of the location description.
11. A network device for providing location description over a network, comprising:
- a transceiver to send and receive data over the network; and
- a processor that is operative to perform actions, comprising: receiving, from a client device associated with a member of a social network, a start location, an end location, and a geographical coordinate, wherein the geographical coordinate identifies a geographical location of the client device; searching the social network for at least one other of a plurality of social network members associated with a location name based in part on a determination of whether the geographical coordinate is within a proximity to another geographical coordinate associated with the location name, and wherein searching that provides a plurality of location name results that is ordered based at least in part on a degree of separation between the member and the at least one other of the plurality of members; determining a location of interest based on the location name; determining a route between the start location and the end location that includes the location of interest providing the location name and the route to the client device; and receiving from the at least one other member a payment for associating the other geographical coordinate and the location name with the other member in the social network, wherein the geographical coordinate is within a proximity to the other geographical coordinate.
12. The network device of claim 11, wherein searching the social network for the other member associated with the location name comprises;
- providing the location name and location description associated with the location name as part of a search result in the plurality of ordered search results; and
- modifying the plurality of ordered search results based in part on a match of at least one search result of the plurality of ordered search results with a search criterion received form the client device, and further based on relevancy information associated with the at least one search result.
13. The network device of claim 11, wherein the processor is further operative to perform actions comprising identifying the location name as a sponsored advertisement in the plurality of ordered search results.
14. The network device of claim 11, wherein searching the social network comprises performing a depth-first search, a breadth first search or an A* search of the social network for the other member.
15. A system for providing location description over a network, comprising:
- a geo-location search component (GSC) operable to perform actions comprising: receiving, from a mobile device associated with a member of a social network, a start location, and end location, a geographical coordinate and search criteria; requesting a social networking manager (SNM) to search the social network based on the geographical coordinate and search criteria, for a community comprising the member and another member, wherein the other member or the community is related to a location name in the social network; requesting from a geo-location tracking (GLT) component, an address associated with the geographical coordinate as the location name, if the location name is absent from the social network; determining a location of interest based on the location name; determining a route between the start location and the end location that includes the location of interest; providing an ordered result of a search for the location name and associated addresses to the mobile device based at least in part on a degree of separation between the member and the at least other member of the social network; providing the route to the mobile device; and
- a geo-location tracking (GLT) component operable to perform actions comprising: providing at least one address associated with a received geographical coordinate; and
- a messenger component in communication with the GSC and operable to perform actions comprising: forwarding a message between the mobile device and a client device associated with the other member based in part on a preference of the other member, if a geographical location of the client device is determined to be within a proximity with the geographical coordinate.
16. The system of claim 15, wherein forwarding the message further comprises:
- forwarding the message based in part on a preference of the other member, wherein the preference includes at least one of a mode of communication, a geographical area to receive the communication, a time to receive the communication, a the required minimal degree of separation between the member and the other member for communication to be allowed before communication is enabled, a block list of members for whom no communication is allowed, or a complete block of communication.
17. The system of claim 15, further comprising a route mapper in communication with the GSC and operable to perform actions comprising:
- determining a route between the start location and the end location and through the location of interest defined by the location name and the GPS coordinate, using at least one of a Moore algorithm, a shortest path algorithm, a lowest traffic time algorithm, a Frank-Wolfe algorithm, or a Wardrop equilibrium algorithm.
18. A processor readable storage medium having processor executable instructions for providing location description over a network, the processor executable instructions configured to enable a processor to perform actions, comprising:
- requesting a search of a social network based on a Geo Positioning System (GPS) start coordinate identifying a geographical location of the client device, a GPS end coordinate, search criteria and on an identity of a user of the client device, wherein the user is a member of the social network;
- receiving a plurality of ordered location information based on the requested search criteria and a degree of separation between the user and at least one of a plurality of other members of the social network, and a route between the GPS start coordinate and the GPS end coordinate through the plurality of ordered location information, wherein each of the plurality of ordered location information is associated with at least another of the plurality of members of the social network; and
- displaying the plurality of ordered location information as a map of ordered points, wherein each of the ordered points is associated with different one of the plurality of ordered location information.
19. The processor readable storage medium of claim 18, wherein the actions further comprises:
- sending an update of information associated with one of the ordered points, wherein the update is configured to enable refining another search of the social network for other location information.
20. The processor readable storage medium of claim 18, wherein the actions further comprises:
- sending a request to add the at least one other member of the social network to a community of the user within the social network, wherein the added other member is configured to enable refining another search of the social network for other location information.
5493692 | February 20, 1996 | Theimer et al. |
5611050 | March 11, 1997 | Theimer |
5835087 | November 10, 1998 | Herz et al. |
5950193 | September 7, 1999 | Kulkarni |
5996006 | November 30, 1999 | Speicher |
6029141 | February 22, 2000 | Bezos et al. |
6112181 | August 29, 2000 | Shear et al. |
6175831 | January 16, 2001 | Weinreich et al. |
6269369 | July 31, 2001 | Robertson |
6317718 | November 13, 2001 | Fano |
6327573 | December 4, 2001 | Walker et al. |
6343317 | January 29, 2002 | Glorikian |
6356879 | March 12, 2002 | Aggarwal et al. |
6421669 | July 16, 2002 | Gilmour et al. |
6433795 | August 13, 2002 | MacNaughton et al. |
6446076 | September 3, 2002 | Burkey et al. |
6449344 | September 10, 2002 | Goldfinger et al. |
6466917 | October 15, 2002 | Goyal et al. |
6549768 | April 15, 2003 | Fraccaroli |
6553310 | April 22, 2003 | Lopke |
6571279 | May 27, 2003 | Herz et al. |
6606657 | August 12, 2003 | Zilberstein et al. |
6618593 | September 9, 2003 | Drutman et al. |
6647257 | November 11, 2003 | Owensby |
6647384 | November 11, 2003 | Gilmour |
6690918 | February 10, 2004 | Evans et al. |
6714931 | March 30, 2004 | Papierniak et al. |
6745178 | June 1, 2004 | Emens et al. |
6819919 | November 16, 2004 | Tanaka |
6834195 | December 21, 2004 | Brandenberg et al. |
6845370 | January 18, 2005 | Burkey et al. |
6859686 | February 22, 2005 | Johnson |
6879994 | April 12, 2005 | Matsliach et al. |
6968178 | November 22, 2005 | Pradhan et al. |
6968179 | November 22, 2005 | De Vries |
7013326 | March 14, 2006 | Suzuki et al. |
7069308 | June 27, 2006 | Abrams |
7071842 | July 4, 2006 | Brady, Jr. |
7096030 | August 22, 2006 | Huomo |
7103370 | September 5, 2006 | Creemer |
7109859 | September 19, 2006 | Peeters |
7177880 | February 13, 2007 | Ruvolo et al. |
7181412 | February 20, 2007 | Fulgoni et al. |
7190960 | March 13, 2007 | Wilson et al. |
7200592 | April 3, 2007 | Goodwin et al. |
7203502 | April 10, 2007 | Wilson et al. |
7236976 | June 26, 2007 | Breitenbach et al. |
7243130 | July 10, 2007 | Horvitz et al. |
7284033 | October 16, 2007 | Jhanji |
7299217 | November 20, 2007 | Oni |
7299222 | November 20, 2007 | Hogan et al. |
7305350 | December 4, 2007 | Bruecken |
7310676 | December 18, 2007 | Bourne |
7324957 | January 29, 2008 | Boys |
7337456 | February 26, 2008 | Nihei |
7343317 | March 11, 2008 | Jokinen et al. |
7343365 | March 11, 2008 | Farnham et al. |
7359688 | April 15, 2008 | Seo et al. |
7359894 | April 15, 2008 | Liebman et al. |
7383243 | June 3, 2008 | Conkwright et al. |
7392057 | June 24, 2008 | Lee |
7403939 | July 22, 2008 | Virdy |
7424541 | September 9, 2008 | Bourne |
7468729 | December 23, 2008 | Levinson |
7469139 | December 23, 2008 | van de Groenendaal |
7484176 | January 27, 2009 | Blattner et al. |
7496623 | February 24, 2009 | Szeto et al. |
7532900 | May 12, 2009 | Wilson et al. |
7533083 | May 12, 2009 | Aoki et al. |
7545784 | June 9, 2009 | Mgrdechian et al. |
7630986 | December 8, 2009 | Herz et al. |
7636779 | December 22, 2009 | Hayashi et al. |
7668832 | February 23, 2010 | Yeh et al. |
7669135 | February 23, 2010 | Cunningham et al. |
7685530 | March 23, 2010 | Sherrard et al. |
7689556 | March 30, 2010 | Garg et al. |
7707520 | April 27, 2010 | Ashtekar et al. |
7721216 | May 18, 2010 | Zaner et al. |
7831384 | November 9, 2010 | Bill |
7860758 | December 28, 2010 | McCrossin et al. |
8005906 | August 23, 2011 | Hayashi et al. |
8019692 | September 13, 2011 | Rosen et al. |
20020016740 | February 7, 2002 | Ogasawara |
20020023132 | February 21, 2002 | Tornabene et al. |
20020023230 | February 21, 2002 | Bolnick et al. |
20020046259 | April 18, 2002 | Glorikian |
20020059092 | May 16, 2002 | Naito et al. |
20020116330 | August 22, 2002 | Hed et al. |
20020116466 | August 22, 2002 | Trevithick et al. |
20020124053 | September 5, 2002 | Adams et al. |
20020147619 | October 10, 2002 | Floss et al. |
20020155844 | October 24, 2002 | Rankin et al. |
20020160766 | October 31, 2002 | Portman et al. |
20020194061 | December 19, 2002 | Himmel et al. |
20030007464 | January 9, 2003 | Balani |
20030050977 | March 13, 2003 | Puthenkulam et al. |
20030061201 | March 27, 2003 | Grefenstette et al. |
20030100993 | May 29, 2003 | Kirshenbaum et al. |
20030137419 | July 24, 2003 | Gehlot et al. |
20030137424 | July 24, 2003 | Gehlot et al. |
20030148775 | August 7, 2003 | Spriestersbach et al. |
20030167324 | September 4, 2003 | Farnham et al. |
20030171977 | September 11, 2003 | Singh et al. |
20040002348 | January 1, 2004 | Fraccaroli |
20040009750 | January 15, 2004 | Beros et al. |
20040014486 | January 22, 2004 | Carlton et al. |
20040088315 | May 6, 2004 | Elder et al. |
20040088322 | May 6, 2004 | Elder et al. |
20040088325 | May 6, 2004 | Elder et al. |
20040093325 | May 13, 2004 | Banerjee et al. |
20040111360 | June 10, 2004 | Albanese |
20040116119 | June 17, 2004 | Lewis et al. |
20040120298 | June 24, 2004 | Evans et al. |
20040122681 | June 24, 2004 | Ruvolo et al. |
20040122803 | June 24, 2004 | Dom et al. |
20040122855 | June 24, 2004 | Ruvolo et al. |
20040128152 | July 1, 2004 | Austin et al. |
20040162830 | August 19, 2004 | Shirwadkar et al. |
20040185885 | September 23, 2004 | Kock |
20040203616 | October 14, 2004 | Minear et al. |
20040203719 | October 14, 2004 | Ross et al. |
20040203901 | October 14, 2004 | Wilson et al. |
20040215793 | October 28, 2004 | Ryan et al. |
20050054352 | March 10, 2005 | Karaizman |
20050096084 | May 5, 2005 | Pohja |
20050108213 | May 19, 2005 | Riise et al. |
20050113137 | May 26, 2005 | Rodriguez et al. |
20050146417 | July 7, 2005 | Sweatte |
20050159970 | July 21, 2005 | Buyukkokten et al. |
20050172001 | August 4, 2005 | Zaner et al. |
20050221807 | October 6, 2005 | Karlsson et al. |
20060064346 | March 23, 2006 | Steenstra et al. |
20060064404 | March 23, 2006 | Kishore et al. |
20060074883 | April 6, 2006 | Teevan et al. |
20060117378 | June 1, 2006 | Tam et al. |
20060155765 | July 13, 2006 | Takeuchi et al. |
20060161599 | July 20, 2006 | Rosen |
20060170945 | August 3, 2006 | Bill |
20060235873 | October 19, 2006 | Thomas |
20060242129 | October 26, 2006 | Libes et al. |
20060256008 | November 16, 2006 | Rosenberg |
20060270419 | November 30, 2006 | Crowley et al. |
20060271518 | November 30, 2006 | Wang et al. |
20070005750 | January 4, 2007 | Lunt et al. |
20070032244 | February 8, 2007 | Counts et al. |
20070118520 | May 24, 2007 | Bliss et al. |
20070130153 | June 7, 2007 | Nachman et al. |
20070174243 | July 26, 2007 | Fritz |
20070260741 | November 8, 2007 | Bezancon |
20070281689 | December 6, 2007 | Altman et al. |
20070293958 | December 20, 2007 | Stehle et al. |
20080005072 | January 3, 2008 | Meek et al. |
20080007399 | January 10, 2008 | Hart |
20080059455 | March 6, 2008 | Canoy et al. |
20080102856 | May 1, 2008 | Fortescue et al. |
20080140650 | June 12, 2008 | Stackpole |
20080168033 | July 10, 2008 | Ott, IV et al. |
20080288355 | November 20, 2008 | Rosen et al. |
20090164309 | June 25, 2009 | Mgrdechian et al. |
20100185580 | July 22, 2010 | Zhu et al. |
20110159890 | June 30, 2011 | Fortescue et al. |
1265151 | December 2002 | EP |
2375921 | November 2002 | GB |
2388493 | November 2003 | GB |
2003-0063757 | July 2003 | KR |
2003-0079472 | October 2003 | KR |
1020040073803 | August 2004 | KR |
2005-0104134 | November 2005 | KR |
1020060050397 | May 2006 | KR |
10-2006-22543 | September 2006 | KR |
9013828 | November 1990 | WO |
0115480 | March 2001 | WO |
0201405 | January 2002 | WO |
0228125 | April 2002 | WO |
0237323 | May 2002 | WO |
02062092 | August 2002 | WO |
2006044939 | April 2006 | WO |
2006044939 | July 2006 | WO |
- International Search Report and Written Opinion of the International Searching Authority mailed Dec. 14, 2007, which issued during the prosecution of International Application No. PCT/US2007/070520.
- “A Sneak Preview of the Christian Connection Matchmaker Match Page,” Feb. 23, 1999, 2 pages http://web.archive.org/web/19990223221053/www.christian.matchmaker.com/ppmatch.
- “A Sneak Preview of the Christian Connection Matchmaker Search Page,” May 8, 1999, 2 pages http://www.webarchive.org/web/19990508232314/www.christian.matchmaker.com/ppsearch.
- “FAQs: About the ZeroDegrees Service,” ZeroDegrees.com, Sep. 8, 2004, 35 pages http://www.zerodegrees.com/faq.htm.
- “The Purpose Principles and Process,” Feb. 24, 1999, 3 pages http://web.archive.org/web/19990224045035/www.christian.matchmaker.com/process.
- “Welcome to the Christian Connection Matchmaker,” Feb. 22, 1999, 1 page http://web.archive.org/web/19990222170152/www.christian.email.net/index.html.
- “Welcome to the Christian Connection Matchmaker,” Feb. 21. 1999, 1 page http://web.archive.org/web/19990221092342/www.christian.matchmakercom/main.
- “Yahoo! Groups—What is the spam policy in Yahoo! Groups? How do I avoid spam?,” Ocober 24, 2002 1 page http://web.archive.org/web/200210224130230/help/us/groups/groups-05.html.
- “Yahoo! Groups: What is a Group?,” Yahoo.com, 1 page, Nov. 3, 2002 http://web.archive.org/web/20021103223155/www.yahoo.com/r/ub.
- “Yahoo! Groups: Getting Started, Groups Account, Groups Features,” Yahoo.com, Oct. 17. 2002, 2 pages http://web.archive.org/web/20021017061719/http://help.yahoo.com/help/groups.
- Cranor, Lorne F. et al., “Spam,” Communications of the ACM, Aug. 1998, 41(8):74-83.
- Dragan, Richard V., “Tribe.net (beta),” PC Magazine, Jan. 20, 2004, 5 pages http://www.pcmag.com/article2/0,1759,1418688,00.asp.
- Ethier, Jason, “Current Research in Social Network Theory,” 10 pages http://upaya.soc.neu.edu/archive/students/Ethier-SocialNetworks.html (accessed Apr. 18, 2004).
- Hines, Matt, “America Online proposes Love.com,” CNET News.com, Dec. 10, 2003, 3 pages http://news.com.com/2100-1032-5118986.html.
- Hines, Matt, “AOL serves up software for BREW” CNET News.com, Dec. 9, 2003, 3 pages http://news.com.com/2100-1038-5117686.html.
- Jordan, Ken et al., “The Augmented Social Network: Building Identity and Trust into the Next-generation Internat,” First Monday: Peer Reviewed Journal on the Internet, 62 pages www.firstmonday.dk/issues/issue8—8/jordan/ (accessed Mar. 11, 2004).
- “Matchmaker.com Disclaimer,” matchmaker.com, 4 pages, Apr. 20, 2000 http://web.archive.org/web/20000420114350/www.christian.matchmaker.com/rules.
- “Member Site Selection Page,” matchmaker.com, 2 pages, Feb. 19, 1999 http://web.archive.org/web/19990219183131/matchmaker.com/newtry.shtml.
- Merrick, Amy, “The Best Way to . . . Find a Date—OK, so true love isn't guaranteed; But there are ways to better the odds,” The Wall Street Journal, New York, NY, Nov. 27, 20000, 5 pages, ProQuest ID 64669169.
- Mullaney, Timothy J., “Diller's Latest Little Bet on the Net” BusinessWeek Online, Mar. 1, 2004, 2 pages http://www.businessweek.com/print/technology/content/mar2004/tc2004031—2820—tc199.h . . .
- “Home Page” myspace.com, 1 page http://www.myspace.com/index.cfm?fuseaction=splash&MyToken=b33c4b2b-0b66-428e-9d0c-84028c7 . . . (accessed Jun. 22, 2006).
- “About Us,” myspace.com, 1 page http://www.myspace.com/index.cfm?fuseaction=misc.aboutus (accessed Aug. 14, 2008).
- “Mobile Phone Technology Opens up New Revenue Streams,” Zi Corporation White Paper, May 2005, 5 pages.
- “Qix Benefits,” Zi Corporation, 2 pages, http://www.zicorp.com/QixBenefits.htm (accessed Apr. 10, 2005).
- “Qix Functions,” Zi Corporation, 2 pages, http://www.zicorp.com/QixFunctions.htm (accessed Apr. 10, 2006).
- International Preliminary Report on Patentability for International Patent Application No. PCT/US2007/070520 mailed May 14, 2009.
- International Search Report and Written Opinion for International Patent Application No. PCT/US2007/086603 mailed Apr. 25, 2008.
- International Preliminary Report on Patentability for International Patent Application No. PCT/US2007/086603 mailed Jul. 16, 2009.
- International Search Report for International Patent Application No. PCT/US2007/066816 mailed Aug. 6, 2008.
- International Preliminary Report on Patentability for International Patent Application No. PCT/US2007/066816 mailed Nov. 6, 2008.
- Official Communication for Australian Patent Application No. 2007342244 mailed May 11, 2010.
- Official Communication for Chinese Patent Application No. 200780015463.3 mailed May 12, 2010.
- Official Communication for Japanese Patent Application No. 2009-507895 mailed Jan. 31, 2011.
- Official Communication for Japanese Patent Application No. 2009-507895 mailed Aug. 29, 2011.
- Official Communication for Korean Patent Application No. 10-2009-7011168 mailed Jan. 20, 2011.
- Official Communication for Korean Patent Application No. 10-2009-7016407 mailed Jul. 30, 2010.
- Official Communication for Korean Patent Application No. 10-2009-7016407 mailed Feb. 28, 2011.
- Official Communication for Korean Patent Application No. 10-2008-7026557 mailed Jan. 6, 2010.
- Official Communication for U.S. Appl. No. 11/380,868 mailed Aug. 19, 2008.
- Official Communication for U.S. Appl. No. 11/380,868 mailed Feb. 20, 2009.
- Official Communication for U.S. Appl. No. 11/380,868 mailed Jun. 15, 2009.
- Official Communication for U.S. Appl. No. 11/380,868 mailed Jul. 8, 2009.
- Official Communication for U.S. Appl. No. 11/380,868 mailed Oct. 29, 2009.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Aug. 13, 2008.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Mar. 4, 2009.
- Official Communication for U.S. Appl. No. 11/555,675 mailed May 27, 2009.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Jul. 7, 2009.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Apr. 1, 2010.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Jun. 16, 2010.
- Official Communication for U.S. Appl. No. 11/555,675 mailed Nov. 26, 2010.
- Official Communication for U.S. Appl. No. 11/620,619 mailed Dec. 8, 2008.
- Official Communication for U.S. Appl. No. 11/620,619 mailed Jun. 9, 2009.
- Official Communication for U.S. Appl. No. 11/620,619 mailed Oct. 15, 2009.
- Official Communication for U.S. Appl. No. 11/620,619 mailed Apr. 14, 2010.
- Official Communication for U.S. Appl. No. 12/117,575 mailed Jan. 5, 2010.
- Official Communication for U.S. Appl. No. 12/117,575 mailed Jun. 17, 2010.
- Official Communication for U.S. Appl. No. 12/117,575 mailed Nov. 24, 2010.
- Official Communication for U.S. Appl. No. 12/117,575 mailed Feb. 3, 2011.
- Official Communication for U.S. Appl. No. 12/117,575 mailed Apr. 15, 2011.
Type: Grant
Filed: Nov 1, 2006
Date of Patent: Jan 31, 2012
Patent Publication Number: 20080104227
Assignee: YAHOO! Inc. (Sunnyvale, CA)
Inventors: Paul Robert Birnie (London), Murray Blake Fortescue (London)
Primary Examiner: Lashonda Jacobs
Attorney: Frommer Lawrence & Haug LLP
Application Number: 11/555,672
International Classification: G06F 15/173 (20060101);