US20100082629A1 - System for associating data items with context - Google Patents
System for associating data items with context Download PDFInfo
- Publication number
- US20100082629A1 US20100082629A1 US12/239,982 US23998208A US2010082629A1 US 20100082629 A1 US20100082629 A1 US 20100082629A1 US 23998208 A US23998208 A US 23998208A US 2010082629 A1 US2010082629 A1 US 2010082629A1
- Authority
- US
- United States
- Prior art keywords
- user
- attribute
- action
- social
- topical
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/02—Marketing; Price estimation or determination; Fundraising
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2457—Query processing with adaptation to user needs
- G06F16/24575—Query processing with adaptation to user needs using context
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2457—Query processing with adaptation to user needs
- G06F16/24578—Query processing with adaptation to user needs using ranking
Definitions
- the present description relates generally to a system and method, generally referred to as a system, for associating data items with context, and more particularly, but not exclusively, to building data stores of contextually relevant data items.
- the mobile phone may be increasingly important as an information and content access device.
- Mobile operators may be increasingly looking to high value data services as a way to overcome the continuing voice average revenue per user (“ARPU”) decline.
- ARPU voice average revenue per user
- a system for providing building a data store of contextually relevant data items.
- the system may include a processor, a memory and an interface.
- the memory may be operatively connected to the processor and the interface and may store an association between a descriptor of an action performed by a user, a spatial attribute of the action, a temporal attribute of the action, a social attribute of the action and a topical attribute of the action.
- the interface may provide contextually relevant data items.
- the processor may identify the action performed by the user and may determine the spatial, temporal, social and topical attributes of the action.
- the spatial attribute of the action may relate to the location of the user.
- the temporal attribute of the action may relate to the time when the user performed the action.
- the social attribute of the action may relate to a social relation of the user.
- the topical attribute may relate to a topic of interest to the user.
- the processor may store an association between a descriptor of the action performed by the user, the spatial attribute of the action, the temporal attribute of the action, the social attribute of the action and the topical attribute of the action in the memory.
- the processor may use the stored association to provide a contextually relevant data item via the interface.
- FIG. 1 is a block diagram of a general overview of a system for associating data items with context.
- FIG. 2 is block diagram of a simplified view of a network environment implementing the system of FIG. 1 or other systems for associating data items with context.
- FIG. 3 is a block diagram of an implementation of the system of FIG. 1 or other systems for associating data items with context.
- FIG. 4 is a block diagram of a workflow of the system of FIG. 1 or other systems for associating data items with context.
- FIG. 5 is an illustration of exemplary contextual attributes associated with a user click action in the system of FIG. 1 , or other systems for associating data items with context.
- FIG. 6 is a flowchart illustrating operations of associating data items with context in the system of FIG. 1 , or other systems for associating data items with context.
- FIG. 7 is a flowchart illustrating operations of building a contextual data store in the system of FIG. 1 , or other systems for associating data items with context.
- FIG. 8 is a flowchart illustrating operations of generating contextual models in the system of FIG. 1 , or other systems for associating data items with context.
- FIG. 9 is a flowchart illustrating operations of providing contextually relevant search results in the system of FIG. 1 or other systems for associating data items with context.
- FIG. 10 is an illustration a general computer system that may be used in a system for associating data items with context.
- a system and method relate to associating data items with context, and more particularly, but not exclusively, to building data stores of contextually relevant data items.
- the principles described herein may be embodied in many different forms.
- the system may allow a service provider to provide search results and/or advertisements that are relevant to the context of a query.
- the context may be determined by one or more contextual attributes, such as a spatial attribute, a temporal attribute, a social attribute, or a topical attribute.
- the system may allow the service provider to retrieve the contextually relevant search results and rank the search results based on their relevancy to the context of the search query.
- the search results most relevant to the context of the search query may be provided to the user.
- the system may provide an advantage over prior art systems by incorporating the context specific to an individual query into the selection of search results, thereby providing more relevant search results to the user.
- the system may allow a service provider to build a data store of contextual user behavior data.
- the data store may include data items describing the actions of a user and the context the action was performed in. Each data item describing an action of the user may be associated with one or more contextual attributes describing the context.
- the contextual attributes may include a spatial attribute, a temporal attribute, a social attribute and a topical attribute.
- the spatial attribute may describe the location of the user while performing the action.
- the temporal attribute may describe the time when the user performed the action.
- the social attribute may describe the behavior of users socially connected to the user.
- the topical attribute may describe topics of interest the user has recently expressed interest in.
- the system may store an association between the action and the contextual attributes in a contextual user behavior data store. The user behavior data store may then be used to determine and provide contextually relevant data items.
- the system may allow a service provider to build contextual user behavior models.
- Each model may reflect the behavior of a user when the user's context falls within the context represented by the model.
- the system may build a model for each context identified in a user behavior data store.
- the models may be used to provide data to a user which is relevant to the context of the user.
- the system may allow a service provider to provide contextually relevant search results.
- the system may build a data store of contextual user behavior data and may generate contextual user behavior models based on the data store.
- the system may receive a search query from a user and may determine the context in which the query was performed.
- the system may retrieve the contextual model correlating to the context in which the query was performed.
- the contextual model may be used to determine the search results relating to the search query which are relevant to the context the query was performed in.
- the search results most relevant to the context may be provided to the user.
- FIG. 1 provides a general overview of a system 100 for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the system 100 may include one or more revenue generators 110 A-N, such as mobile advertisers, a service provider 130 , such as a portal, one or more mobile network operators (“MNOs”) 115 A-N, more commonly referred to as mobile carriers, or simply carriers, and one or more users 120 AA-NN, such as mobile subscribers or consumers.
- the service provider 130 may implement an advertising campaign management system incorporating an auction based and/or non-auction based advertisement serving system.
- the revenue generators 110 A-N may pay the service provider 130 to serve, or display, advertisements of their goods or services, such as mobile advertisements, to the users 120 AA-NN, such as over mobile messaging, mobile web, the Internet, or generally any venue for displaying advertisements.
- the advertisements may include sponsored listings, banners ads, popup advertisements, mobile messaging advertisements, or generally any way of attracting the users 120 AA-NN to the web site or mobile site of the revenue generators 110 A-N.
- the users 120 AA-NN may utilize the services of the service provider 130 through web applications, mobile applications, such as mobile messaging applications, or standalone applications.
- the service provider 130 may maintain a mobile portal and/or a web portal, such as a search site, where the service provider 130 may display advertisements of the revenue generators 110 A-N to the users 120 AA-NN.
- the service provider 130 may share revenue with the mobile network operators MNOs 115 A-N of the users 120 AA-NN for displaying advertisements of the revenue generators 110 A-N via their mobile networks.
- the service provider 130 may share revenue with individual publishers for displaying advertisements of the revenue generators 110 A-N on their mobile and/or web sites.
- the MNOs 115 A-N may provide a mobile network to the users 120 AA-NN which may provide a variety of services to the users 120 AA-NN, such as the ability to send and receive phone calls, send and receive mobile messages, to access the internet and/or the mobile web, or generally any service that may be implemented on a mobile device.
- the MNOs 115 A-N may store data describing the users 120 AA-NN, such as billing addresses, call histories, messaging histories, or generally any data regarding the users 120 AA-NN that may be available to the MNOs 115 A-N.
- the service provider 130 may provide an application programming interface (“API”) to the MNOs 115 A-N to allow the MNOs 115 A-N to access the mobile search and mobile advertising services of the service provider 130 .
- the MNOs 115 A-N may make a call to the API to retrieve search results or mobile advertisements from the service provider 130 .
- the amount the revenue generators 110 A-N may pay the service provider 130 for displaying advertisements may be based on one or more factors. These factors may include impressions, click throughs, conversions, and/or generally any metric relating to the advertisement and/or the behavior of the users 120 AA-NN.
- the impressions may refer to the number of times an advertisement may have been displayed to the users 120 AA-NN.
- the click throughs may refer to the number of times the users 120 AA-NN may have clicked through an advertisement to a web site, mobile web site or mobile landing page of one of the revenue generators 110 A-N, such as the revenue generator A 110 A.
- the conversions may refer to the number of times a desired action was taken by the users 120 AA-NN after clicking though to a web site of the revenue generator A 110 A.
- the desired actions may include submitting a sales lead, making a purchase, viewing a key page of the site, downloading a whitepaper, and/or any other measurable action. If the desired action is making a purchase, then the revenue generator A 110 A may pay the service provider 130 a percentage of the purchase.
- the users 120 AA-NN may also be consumers of goods or services who may be searching for a business, such as the business of one of the revenue generators 110 A-N.
- the users 120 AA-NN may be associated with one another via a social relation to one or more of the other users 120 AA-NN.
- the social relation may be an explicit relationship, such as a relationship coded in a social network.
- the social relation may be an implicit, implied, or inferred relationship, such as a relationship based on the actual number, frequency, length, or subject matter of contacts between users.
- the social relation may associate the users 120 AA-NN who share a common interest.
- the users 120 AA-NN may be linked based on shared demographics. For example, all of the users 120 AA-NN of the same age range, and/or gender, may be associated together.
- the users 120 AA-NN may be machines or other servers, such as the third party server 250 .
- the users 120 AA-NN may need a user identifier or identification (“user ID”) to access the services of the service provider 130 .
- user ID user identifier or identification
- the users 120 AA-NN may need to supply information describing themselves to the service provider 130 , such as the location, gender, or age of the users 120 AA-NN, or generally any information that may be required for the users 120 AA-NN to utilize the services provided by the service provider 130 .
- the service provider 130 may collect user behavior data from the users 120 AA-NN, such as queries searched for by the users 120 AA-NN, links clicked on by the users 120 AA-NN and/or any user interactions with the services provided by the service provider 130 .
- the service provider 130 may associate each piece of user behavior data with one or more contextual attributes.
- the contextual attributes may associate a subject matter or other keyword that designates an interest, activity or association of the user with that subject, topic or real-world object.
- the contextual attributes may describe the context at the time the users 120 AA-NN generated the user behavior data. Alternatively or in addition the contextual attributes may be relative to other users or other queries.
- the contextual attributes may include a spatial attribute, a temporal attribute, a topical attribute, and a social attribute.
- the spatial attribute may describe the location of the user AA 120 AA.
- the temporal attribute may describe the time when the user AA 120 A interacted with the service provider 130 .
- the topical attribute may describe the topics that the user AA 120 AA has recently showed interest in. Alternatively or in addition the topical attribute may represent the subject matter of the query.
- the social attribute may describe the topics that the users 120 AA-NN in a social relationship with the user AA 120 AA have shown interest in. Alternatively or in addition the social attribute may represent an association or relation of the user with other users.
- the service provider 130 may receive a search request from a user AA 120 AA and provide contextually relevant search results and/or advertisements to the user AA 120 AA.
- Contextually relevant data may be determined by analyzing user behavior data sharing the same contextual attributes as the current search query.
- the user behavior data sharing the same contextual attributes as the current search query may be used to determine which search results and/or advertisements the user AA 120 AA may be most likely to click on.
- the search results and/or advertisements the user AA 120 AA may be most likely to click on may be the most relevant search results and/or advertisements.
- the revenue generators 110 A-N may interact with the service provider 130 , such as via a web application.
- the revenue generators 110 A-N may send information, such as billing, website or mobile site and advertisement information, to the service provider 130 via the web application.
- the web application may include a web browser or other application such as any application capable of displaying web content.
- the application may be implemented with a processor such as a personal computer, personal digital assistant, mobile phone, or any other machine capable of implementing a web application.
- the users 120 AA-NN may also interact individually with the service provider 130 , through the mobile network operators 115 A-N, such as via a mobile phone or any mobile device capable of communicating with the mobile network operators 115 A-N.
- the users 120 AA-NN may interact with the service provider 130 via a mobile web based application, a mobile standalone application, or any application capable of running on a mobile device.
- the service provider 130 may communicate data to the revenue generators 110 A-N over a network and to the users 120 AA-NN over a network via the MNOs 115 A-N.
- the following examples may refer to a revenue generator A 110 A as an online advertiser or mobile advertiser; however the system 100 may apply to any revenue generators 110 A-N who may wish to serve advertisements over mobile devices.
- a revenue generator A 110 A who is an advertiser may maintain one or more accounts with the service provider 130 . For each account the revenue generator A 110 A may maintain one or more campaigns. For each campaign the revenue generator A 110 A may maintain one or more listings.
- a listing may include a keyword, an advertisement title, an advertisement description, a bid amount and a network address, if any, such as a uniform resource locator (“URL”).
- a listing may represent an association between a keyword and an advertisement.
- the listing may be associated with a context descriptor.
- the context descriptor may describe a context surrounding a user AA 120 AA when the user AA 120 AA searches for the query.
- the context descriptor may include one or more attributes, such as a spatial attribute, a temporal attribute, a social attribute or a topical attribute.
- the spatial attribute may describe the location of the user AA 120 AA when the user AA 120 AA searches for the query.
- the temporal attribute may describe a time, or time of day, when the user AA 120 AA searches for the query.
- the social attribute may describe an item of interest to user 120 BB-N within a social relation of the user AA 120 AA searching for the query.
- the topical attribute may describe a topical interest of the user AA 120 AA searching for the query.
- a revenue generator A 110 A may associate different versions of the advertisements for different contexts. For example, the revenue generator A 110 A may wish to associate a different advertisement with a query depending on whether the user AA 120 AA searches for the query in the evening or in the morning.
- the keywords may represent one or more search terms that the revenue generator A 110 A wishes to associate with their advertisement.
- the advertisement title may represent the data the revenue generator A 110 A wishes to be displayed to a user AA 120 AA.
- the network address may represent the link the revenue generator A 110 A wishes a user AA 120 AA to be directed to upon clicking on the advertisement of the revenue generator A 110 A, such as the home page of the revenue generator A 110 A.
- the bid amount may represent a maximum amount the revenue generator A 110 A may be willing to pay each time a user AA 120 AA may click on the advertisement of the revenue generator A 110 A or each time the advertisement of the revenue generator A 110 A may be shown to a user AA 120 AA, such as in a mobile message.
- the user AA 120 AA may search for a query via a search service provided by the service provider 130 .
- the service provider 130 may determine the contextual attributes at the time the user AA 120 AA performs the search.
- the service provider 130 may retrieve historical user behavior data, such as historical user click data, sharing the same contextual attributes as the search of the user AA 120 AA.
- the historical user click data may be represented by a model of click data of users 120 AA-NN sharing the same contextual attributes as the user AA 120 AA.
- the model may take the query searched for by the user AA 120 AA as an input and may output the search results and/or advertisements most relevant to the user AA 120 AA. Alternatively the model may take the query search for by the user AA 120 AA and the contextual attributes as inputs.
- the service provider 130 may generate reports based on the data collected from the users 120 AA-NN and communicate the reports to the revenue generators 110 A-N to assist the revenue generators 110 A-N in measuring the effectiveness of their advertising.
- the reports may indicate the number of times the users 120 AA-NN viewed a mobile advertisement of the revenue generators 110 A-N, the number of times a mobile advertisement of the revenue generators 110 A-N was clicked on by the users 120 AA-NN, the contextual attributes of the users 120 AA-NN, or generally any information useful to the revenue generators 110 A-N.
- the reports may be segmented based on one or more of the contextual attributes.
- the reports may also generally indicate any data that may assist the revenue generators 110 A-N in measuring the effectiveness of their mobile advertising campaigns.
- FIG. 2 provides a simplified view of a network environment implementing a system 200 for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the system 200 may include one or more web applications, standalone applications and mobile applications 210 A-N, which may be collectively or individually referred to as client applications of the revenue generators 110 A-N.
- the system 200 may also include one or more mobile applications, such as mobile messaging applications and/or mobile browsers, which may be running on one or more mobile devices 220 AA-NN.
- the system 200 may also include one or more MNO gateway servers 215 A-N, a network 230 , a network 235 , the service provider server 240 , a third party server 250 , and an advertising services server 260 .
- Some or all of the advertisement services server 260 , service provider server 240 , and third-party server 250 may be in communication with each other by way of network 235 and may be the system or components described below in FIG. 10 .
- the advertisement services server 260 , third-party server 250 and service provider server 240 may each represent multiple linked computing devices. Multiple distinct third party servers, such as the third-party server 250 , may be included in the system 200 .
- the third-party server 250 may be an MNO gateway server 215 A-N or a server associated with, or in communication with an MNO gateway server 215 A-N.
- the networks 230 , 235 may include wide area networks (“WAN”), such as the internet, mobile networks, local area networks (“LAN”), campus area networks, metropolitan area networks, or any other networks that may allow for data communication.
- the network 230 may include the Internet and may include all or part of network 235 ; network 235 may include all or part of network 230 .
- the networks 230 , 235 may be divided into sub-networks. The sub-networks may allow access to all of the other components connected to the networks 230 , 235 in the system 200 , or the sub-networks may restrict access between the components connected to the networks 230 , 235 .
- the network 235 may be regarded as a public or private network connection and may include, for example, a virtual private network or an encryption or other security mechanism employed over the public Internet, or the like.
- the revenue generators 110 A-N may use a web application 210 A, standalone application 210 B, or a mobile application 210 N, or any combination thereof, to communicate to the service provider server 240 , such as via the networks 230 , 235 .
- the service provider server 240 may communicate to the revenue generators 110 A-N via the networks 230 , 235 , through the web applications, standalone applications or mobile applications 210 A-N.
- the users 120 AA-NN may use a mobile application running on a mobile device 220 AA- 220 NN, such as a mobile web browser, to communicate with the service provider server 240 , via the MNO gateway servers 215 A-N and the networks 230 , 235 .
- the service provider server 240 may communicate to the users 120 AA-NN via the networks 230 , 235 and the MNO gateway servers 215 A-N, through the mobile devices 220 AA-NN.
- the web applications, standalone applications, mobile applications and mobile devices 210 A-N, 220 AA-NN may be connected to the network 230 in any configuration that supports data transfer. This may include a data connection to the network 230 that may be wired or wireless. Any of the web applications, standalone applications and mobile applications 210 A-N, may individually be referred to as a client application.
- the web application 210 A may run on any platform that supports web content, such as a web browser or a computer, a mobile phone, personal digital assistant (“PDA”), pager, network-enabled television, digital video recorder, such as TIVO®, automobile and/or any appliance capable of data communications.
- PDA personal digital assistant
- the standalone applications 210 B may run on a machine that may have a processor, memory, a display, a user interface and a communication interface.
- the processor may be operatively connected to the memory, display and the interfaces and may perform tasks at the request of the standalone application 210 B or the underlying operating system.
- the memory may be capable of storing data.
- the display may be operatively connected to the memory and the processor and may be capable of displaying information to the revenue generator B 110 B.
- the user interface may be operatively connected to the memory, the processor, and the display and may be capable of interacting with a revenue generator B 110 B.
- the communication interface may be operatively connected to the memory, and the processor, and may be capable of communicating through the networks 230 , 235 with the service provider server 240 , third party server 250 and advertising services server 260 .
- the standalone application 210 B may be programmed in any programming language that supports communication protocols. These languages may include: SUN JAVA, C++, C#, ASP, SUN JAVASCRIPT, asynchronous SUN JAVASCRIPT, or ADOBE FLASH ACTIONSCRIPT, amongst others.
- the mobile application 210 N may run on any mobile device which may have a data connection.
- the mobile applications 210 N may be a web application 210 A, a standalone application 210 B, a mobile messaging application, a mobile browser, or a microbrowser.
- the mobile devices 220 AA-NN may be one of a broad range of electronic devices which may include mobile phones, PDAs, and laptops and notebook computers.
- the mobile devices 220 AA-NN may have a reduced feature set, such as a smaller keyboard and/or screen, and may be incapable of supporting a traditional web search.
- the data connection of the mobile devices 220 AA-NN may be a cellular connection, such as a GSM/GPRS/WCDMA connection, a wireless data connection, an internet connection, an infra-red connection, a Bluetooth connection, or any other connection capable of transmitting data.
- the data connection may be used to connect directly to the network 230 , or to connect to the network 230 through the MNO gateway servers 215 A-N.
- the MNO gateway servers 215 A-N may control the access the mobile devices 220 AA-NN may have to the network.
- the MNO gateway servers 215 A-N may also control the technology supporting the respective mobile devices 220 AA-NN. This may affect aspects of the user experience, such as signal strength and availability, speed and billing mechanisms.
- the MNO gateway server A 215 A may only allow the users 120 AA-NA access to content provided by partners of the MNO A 115 A.
- the MNO gateway servers 215 A-N may only allow users 120 AA-NN access to data in a specific format, such as WML, XHTML, NTT DOCOMO IMODE HTML, or cHTML.
- the mobile devices 220 AA-NN may only support one of the aforementioned formats.
- the service provider server 240 may include one or more of the following: an application server, a data source, such as a database server, a middleware server, and an advertising services server.
- a middleware server may be a mobile commerce platform, such as the YAHOO! SUSHI platform, which may properly encode data, such as mobile pages or mobile advertisements, to the formats specific to the MNO gateway servers 215 A-N.
- the service provider server 240 may co-exist on one machine or may be running in a distributed configuration on one or more machines.
- the service provider server 240 may collectively be referred to as the server.
- the service provider server 240 may receive requests from the users 120 AA-NN and the revenue generators 110 A-N and may serve mobile pages to the users 120 AA-NN and web pages and/or mobile pages to the revenue generators 110 A-N based on their requests.
- the third party server 250 may include one or more of the following: an application server, a data source, such as a database server, a middleware server, and an advertising services server.
- the third party server 250 may co-exist on one machine or may be running in a distributed configuration on one or more machines.
- the advertising services server 260 may provide a platform for the inclusion of advertisements in pages, such as web pages or mobile pages.
- the advertisement services server 260 may be used for providing mobile advertisements that may be displayed to the users 120 AA-NN.
- the service provider server 240 , the third party server 250 and the advertising services server 260 may be one or more computing devices of various kinds, such as the computing device in FIG. 10 .
- Such computing devices may generally include any device that may be configured to perform computation and that may be capable of sending and receiving data communications by way of one or more wired and/or wireless communication interfaces.
- Such devices may be configured to communicate in accordance with any of a variety of network protocols, including but not limited to protocols within the Transmission Control Protocol/Internet Protocol (“TCP/IP”) protocol suite.
- TCP/IP Transmission Control Protocol/Internet Protocol
- the web application 210 A may employ HTTP to request information, such as a web page, from a web server, which may be a process executing on the service provider server 240 or the third-party server 250 .
- Database servers may include MICROSOFT SQL SERVER, ORACLE, IBM DB2 or any other database software, relational or otherwise.
- the application server may be APACHE TOMCAT, MICROSOFT IIS, ADOBE COLDFUSION, YAPACHE or any other application server that supports communication protocols.
- the middleware server may be any middleware that connects software components or applications.
- the application server on the service provider server 240 or the third party server 250 may serve pages, such as web pages to the users 120 AA-NN and the revenue generators 110 A-N.
- the advertising services server may provide a platform for the inclusion of advertisements in pages, such as web pages.
- the advertising services server 260 may also exist independent of the service provider server 240 and the third party server 250 .
- the networks 230 , 235 may be configured to couple one computing device to another computing device to enable communication of data between the devices.
- the networks 230 , 235 may generally be enabled to employ any form of machine-readable media for communicating information from one device to another.
- Each of networks 230 , 235 may include one or more of a wireless network, a wired network, a local area network (“LAN”), a wide area network (“WAN”), a direct connection such as through a Universal Serial Bus (“USB”) port, and the like, and may include the set of interconnected networks that make up the Internet.
- the networks 230 , 235 may include any communication method by which information may travel between computing devices.
- FIG. 3 illustrates a block diagram of an implementation 300 of the system of FIG. 1 or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the implementation 300 may include a user AA 120 AA, a mobile device 220 AA, a network 230 , a service provider server 240 , a contextual data store 320 , a models data store 330 , and a results data store 340 .
- the service provider server 240 may include an interface 310 , an input processor 312 , a training processor 316 and a ranking processor 314 .
- the interface 310 may allow the service provider server 240 to communicate with the mobile device 220 AA over the network 230 .
- the processors 312 , 314 , 316 may be located on the same physical machine or, or may be running across several machines in a distributed environment.
- the user AA 120 AA may interact with a service of the service provider server 240 via the mobile device 220 AA over the network 230 .
- the mobile device 220 AA may communicate with the service provider server 240 via the interface 310 .
- the interface 310 may receive an indication of an action performed by the user AA 120 AA, such as when the user AA 120 AA clicks on a search result after searching for a query.
- the interface 310 may communicate the action to the input processor 312 .
- the input processor 312 may determine the contextual attributes associated with the action, such as a spatial attribute, a temporal attribute, a topical attribute and a social attribute.
- the input processor 312 may determine the spatial attribute based on a positioning system implemented by the mobile device 220 AA, and/or based on a network address of the mobile device 220 AA.
- the input processor 312 may store an association between the contextual attributes, the query searched for by the user AA 120 AA, and the search result clicked on by the user AA 120 AA in the contextual data store 320 .
- the input processor 312 may then provide a forwarding network address associated with the search result clicked on to the mobile device of the user AA 120 AA.
- the training processor 316 may generate one or more models representing the behavior of users 120 AA-NN within a given context based on the data stored in the contextual data store 320 .
- the training processor 316 may create a model for each context represented in the contextual data store 320 , or may create a model for the most commonly represented contexts in the contextual data store 320 .
- the training processor 316 may analyze the historical click data of the users 120 AA-NN within a given context to generate a model for each context capable of determining the most relevant search results and/or advertisements for a user AA 120 AA within the context.
- the user AA 120 AA may perform a search for a query via a service provided by the service provider server 240 .
- the service provider server 240 may receive the search query via the interface 310 .
- the interface 310 may communicate the search query to the input processor 312 .
- the input processor 312 may determine the context in which the search query was performed.
- the input processor 312 may retrieve the model from the models data store 330 representing the context of the user AA 120 AA.
- the input processor 312 may provide the model and the search query to the ranking processor 314 .
- the ranking processor 314 may use the model to retrieve the search results in the results data store 340 which are most relevant to the context of the user AA 120 AA.
- the ranking processor 314 may use the model to retrieve advertisements relevant to the context of the user AA 120 AA from the results data store 340 .
- the ranking processor 314 may provide the search results most relevant to the context of the user AA 120 AA to the interface 310 .
- the number of search results provided to the interface 310 may be dependent on the display capacity of the mobile device 220 AA of the user AA 120 AA.
- the interface 310 may provide the results to the mobile device 220 AA via the network 230 .
- FIG. 4 illustrates a block diagram of a workflow of the system of FIG. 1 or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the workflow 300 of the system 100 may include the contextual data store 320 , the training processor 316 , the models data store 330 , the input processor 312 , the ranking processor 314 , the user AA 120 AA, and the mobile device 220 AA.
- the workflow 100 of the system 100 may start with the contextual data store 320 .
- the contextual data store 320 may include data describing the actions of the users 120 AA-NN, such as user click data. Each action may be associated with one or more contextual attributes, such as a spatial attribute, a temporal attribute, a social attribute, and a topical attribute.
- the data from the contextual data store 320 may be provided to the training processor 316 .
- the training processor 316 may analyze the data in the contextual data store 320 to generate a model for each of the contexts represented in the contextual data store.
- the models may reflect the historical behavior of the users 120 AA-NN within the context represented by each model.
- the training processor 316 may then store the models in the models data store 330 .
- a model may be retrieved from the models data store 330 by the input processor 312 when a user AA 120 AA searches for a search query via the mobile device 220 AA.
- the input processor 312 may determine the context the search query was performed in, and may retrieve the model corresponding to the context.
- the input processor 312 may provide the model retrieved from the models data store 330 , and the query searched for by the user AA 120 AA, to the ranking processor 314 .
- the ranking processor 314 may use the model to select the search results and or advertisements most relevant to the context of the user AA 120 AA determined by the input processor 312 for the search query.
- the ranking processor 314 may rank the search results based on their relevancy, in the model, to the search query and may provide the ranked search results to the mobile device 220 AA of the user AA 120 AA.
- FIG. 5 illustrates exemplary contextual attributes associated with a user click action in the system of FIG. 1 , or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the system 100 may determine the context of a user action 520 when the user AA 120 AA performs an action.
- An association between the context and the user action 520 may be stored in the contextual data store 320 .
- the context of a user action 520 may be based on a social attribute 522 , a topical attribute 524 , a temporal attribute 526 , and a local attribute 528 .
- the system 100 may also store an association with the search query which generated the search result.
- the social attribute 522 of the user action 520 may describe the recent actions of the other users 120 BB-NN associated with the user AA 120 AA, such as users 120 BB-NN associated with the user AA 120 AA through a social relation.
- the social relations of the user AA 120 AA may be determined based on a service offered by the service provider 130 or by a third party server 250 .
- the social attribute 522 may describe the behavior of the users 120 BB-NN sharing a social relation with the user AA 120 AA.
- the behavior of the users 120 BB-NN may include expressing interest in an item, such as by reading a news article, clicking on search results, visiting places, buying items, connecting with other people, participating in groups and/or group activities, or generally expressing interest in any topical, spatial, or social issues and items.
- the social attribute 522 may be determined by analyzing the click data of the users 120 BB-NN associated with the user AA 120 AA.
- the topical attribute 524 of the user action 520 may describe the recent actions of the user AA 120 AA.
- the recent actions of the user AA 120 AA may include items recently of interest to the user AA 120 AA, such as news articles read by the user AA 120 AA, search results clicked on by the user AA 120 AA, or generally any items the user AA 120 AA previously expressed interest in.
- the topical attribute 524 may be determined by analyzing the click data of the user AA 120 AA.
- the social attributes 522 and the topical attributes 524 may be selected from a group of categories.
- the categories may generally relate to topics of interests to the users 120 AA-NN, such as sports, news, music, video, or generally any topic of interest to users 120 AA-NN.
- the topics may be determined based on metrics measuring general topics of interest to the users 120 AA-NN.
- the categories may contain more specific sub-categories.
- the category of sports may have subcategories such as football, baseball, basketball, hockey, or generally any sport that may be of interest to the users 120 AA-NN.
- the system 100 may analyze the content of the pages visited by the users 120 AA-NN to determine which categories the website relates to.
- a third party server 250 may provide categories for each web site, or may determine the category a website relates to.
- the temporal attribute 526 of the user action 520 may be the time the user AA 120 AA performed the user action 520 .
- the temporal attribute 526 may be the time the user AA 120 AA clicked on a link.
- the temporal attribute 526 may be determined based on a timestamp associated with the action performed by the user AA 120 AA.
- the spatial attribute 528 of a user action 520 may be the location of the user AA 120 AA when the user AA 120 AA performs the user action 520 .
- the location of the user AA 120 AA may be determined by a positioning system implemented by the mobile device 220 AA, such as a global positioning system, a cell phone tower triangulation system, a wireless internet signal triangulation system, or generally any system capable of determining the location of a user AA 120 A.
- the location of the user AA 120 AA may be determined based on the network address associated with the mobile device 220 AA, may be determined based on the content of the search query, or generally maybe determined based on other analytical methods.
- the location of the user AA 120 AA may be determined based on a known location of a user who is known to be within a close proximity of the user AA 120 AA.
- FIG. 6 is a flowchart illustrating operations of associating data items with context in the system of FIG. 1 , or other systems for associating data items with context.
- the service provider 130 stores data describing user actions 520 , and the contextual data 522 , 524 , 526 , 528 associated with each user action 520 , in the contextual data store 320 .
- the service provider 130 may store data describing the user actions 520 over a period of time before generating the models. Alternatively the service provider 130 may add data to the contextual data store 320 until the contextual data store 320 contains enough data to generate reliable models.
- the training processor 316 generates models for each of the contexts stored in the contextual data store 320 .
- a model of a given context may contain all of the user action data associated with the context.
- the models may be stored in the models data store 330 .
- the system 100 may generate models for contexts that only share one of the contextual attributes 522 , 524 , 526 , 528 in common, such as the spatial attribute 528 .
- the system 100 may receive a search query from one of the users 120 AA-NN, such as the user AA 120 AA.
- the system 100 may identify the contextual attributes 522 , 524 , 526 , 528 associated with the search query received from the user AA 120 AA.
- the system 100 may select a model from the models data store 330 that corresponds to the contextual attributes of the search query identified in block 640 .
- the selected data model may correlate to one or more of the contextual attributes associated with the search query.
- the ranking processor 314 may use the selected model to rank the search results retrieved for the search query.
- the selected model may allow the ranking processor 314 to incorporate the context of the search query into the ranking of the search results.
- the search results may be paid advertisements listings, unpaid search listings, or a combination of paid advertisement listings and unpaid search listings.
- the service provider 130 may provide the ranked results to the user AA 120 AA.
- FIG. 7 is a flowchart illustrating operations of building a contextual data store in the system of FIG. 1 , or other systems for associating data items with context.
- the service provider 130 identifies an action of one of the users 120 AA-NN, such as the user AA 120 AA clicking on a search result.
- the service provider 130 determines the spatial attribute 528 of the user action 520 .
- the spatial attribute 528 may describe the location of the user AA 120 AA.
- the location of the user AA 120 AA may be determined by a positioning system implemented by the mobile device 220 AA of the user AA 120 AA, or by analyzing data associated with the mobile device 220 AA, such as the network address of the mobile device 220 AA.
- the service provider 130 may determine the temporal attribute 526 of the user action 520 .
- the temporal attribute 526 may describe the time when the user AA 120 AA performed the action.
- the service provider 130 may determine the social attribute 522 of the user action 520 .
- the social attribute 522 may describe the interests of the users 120 BB-NN associated with the user AA 120 AA, such as through a social relation.
- the service provider 130 may determine the topical attribute 524 of the user action 520 .
- the topical attribute 524 may describe the topics the user AA 120 AA has recently expressed interest in, such as a category describing web sites recently visited by the user AA 120 AA.
- the service provider 130 may store an association between the user action 520 , in this case the search result clicked on by the user AA 120 AA, the spatial attribute 528 , the temporal attribute 526 , the social attribute 522 and the topical attribute 524 in the contextual data store 320 .
- the service provider 130 may also store an association with the search query.
- the service provider 130 may use the stored association to provide contextually relevant data. For example, the service provider 130 may use the stored association to determine a search result contextually relevant to a search query.
- FIG. 8 is a flowchart illustrating operations of generating contextual models in the system of FIG. 1 , or other systems for associating data items with context.
- the service provider 130 may determine data items associated with contextual data, such as user actions 520 associated with contextual attributes 522 , 524 , 526 , 528 stored in the contextual data store 320 .
- the training processor 316 may generate a model for each of the contexts represented in the contextual data store 320 .
- a model may consist of the data describing the user actions 520 associated with the context represented by the model.
- the service provider 130 may store the models in the models data store 330 .
- the service provider 130 may use a model to provide a contextually relevant data item, such a contextually relevant search result.
- a model sharing a context with a query search may take the query search as an input and may output an indication of the search results contextually relevant to the query search.
- FIG. 9 is a flowchart illustrating operations of providing contextually relevant search results in the system of FIG. 1 or other systems for associating data items with context.
- the service provider 130 may receive a search query from one of the users 120 AA-NN, such as the user AA 120 AA.
- the service provider 130 may determine the location of the user AA 120 AA.
- the location of the user AA 120 AA may be retrieved from a positioning system implemented by the mobile device 220 AA of the user AA 120 AA.
- the location of the user may be determined based on the network address associated with the mobile device 220 AA of the user AA 120 AA or by other analytical methods.
- the service provider 130 may determine the time the search query was received from the user AA 120 AA, such as through a timestamp associated with receiving the search query.
- the service provider 130 may determine a social context of the search query. The service provider may determine any social networks the user AA 120 AA is associated with and/or any demographic groups the user AA 120 AA belongs to. The service provider may determine any social relationships of the user AA 120 AA and/or any demographic groups the user AA 120 AA belongs to. The service provider 130 may then determine the topics recently searched for by other users 120 BB-NN associated with the user AA 120 AA.
- the service provider 130 may determine the recent topics of interests of the user AA 120 AA.
- the recent topics of interest may correspond to the links recently clicked on by the user AA 120 AA.
- the service provider 130 may identify the search results in that are associated with the determined contextual attributes.
- the service provider 130 may determine the most relevant search result.
- the most relevant search result may be the search result which was most frequently clicked on after performing a search sharing the contextual attributes of the current search. Alternatively or in addition the most relevant search result may be based on one or more other factors, such as in the case of advertisements the amount bid on the advertisement.
- the system 100 may provide the most relevant search result to the mobile device 220 AA of the user AA 120 AA.
- the number of most relevant search results provided to the mobile device 220 AA may depend on the number of search results the mobile device 220 AA is capable of displaying at a time.
- FIG. 10 illustrates a general computer system 1000 , which may represent a service provider server 240 , a third party server 250 , an advertising services server 260 , a training processor 316 , an input processor 312 , a ranking processor 314 , or any of the other computing devices referenced herein. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided.
- the computer system 1000 may include a set of instructions 1024 that may be executed to cause the computer system 1000 to perform any one or more of the methods or computer based functions disclosed herein.
- the computer system 1000 may operate as a standalone device or may be connected, e.g., using a network, to other computer systems or peripheral devices.
- the computer system may operate in the capacity of a server or as a client user computer in a server-client user network environment, or as a peer computer system in a peer-to-peer (or distributed) network environment.
- the computer system 1000 may also be implemented as or incorporated into various devices, such as a personal computer (“PC”), a tablet PC, a set-top box (“STB”), a personal digital assistant (“PDA”), a mobile device, a palmtop computer, a laptop computer, a desktop computer, a communications device, a wireless telephone, a land-line telephone, a control system, a camera, a scanner, a facsimile machine, a printer, a pager, a personal trusted device, a web appliance, a network router, switch or bridge, or any other machine capable of executing a set of instructions 1024 (sequential or otherwise) that specify actions to be taken by that machine.
- PC personal computer
- PDA personal digital assistant
- the computer system 1000 may be implemented using electronic devices that provide voice, video or data communication. Further, while a single computer system 1000 may be illustrated, the term “system” shall also be taken to include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions.
- the computer system 1000 may include a processor 1002 , such as, a central processing unit (“CPU”), a graphics processing unit (“GPU”), or both.
- the processor 1002 may be a component in a variety of systems.
- the processor 1002 may be part of a standard personal computer or a workstation.
- the processor 1002 may be one or more general processors, digital signal processors, application specific integrated circuits, field programmable gate arrays, servers, networks, digital circuits, analog circuits, combinations thereof, or other now known or later developed devices for analyzing and processing data.
- the processor 1002 may implement a software program, such as code generated manually (i.e., programmed).
- the computer system 1000 may include a memory 1004 that can communicate via a bus 1008 .
- the memory 1004 may be a main memory, a static memory, or a dynamic memory.
- the memory 1004 may include, but may not be limited to computer readable storage media such as various types of volatile and non-volatile storage media, including but not limited to random access memory, read-only memory, programmable read-only memory, electrically programmable read-only memory, electrically erasable read-only memory, flash memory, magnetic tape or disk, optical media and the like.
- the memory 1004 may include a cache or random access memory for the processor 1002 .
- the memory 1004 may be separate from the processor 1002 , such as a cache memory of a processor, the system memory, or other memory.
- the memory 1004 may be an external storage device or database for storing data. Examples may include a hard drive, compact disc (“CD”), digital video disc (“DVD”), memory card, memory stick, floppy disc, universal serial bus (“USB”) memory device, or any other device operative to store data.
- the memory 1004 may be operable to store instructions 1024 executable by the processor 1002 .
- the functions, acts or tasks illustrated in the figures or described herein may be performed by the programmed processor 1002 executing the instructions 1024 stored in the memory 1004 .
- processing strategies may include multiprocessing, multitasking, parallel processing and the like.
- the computer system 1000 may further include a display 1014 , such as a liquid crystal display (“LCD”), an organic light emitting diode (“OLED”), a flat panel display, a solid state display, a cathode ray tube (“CRT”), a projector, a printer or other now known or later developed display device for outputting determined information.
- the display 1014 may act as an interface for the user to see the functioning of the processor 1002 , or specifically as an interface with the software stored in the memory 1004 or in the drive unit 1006 .
- the computer system 1000 may include an input device 1012 configured to allow a user to interact with any of the components of system 1000 .
- the input device 1012 may be a number pad, a keyboard, or a cursor control device, such as a mouse, or a joystick, touch screen display, remote control or any other device operative to interact with the system 1000 .
- the computer system 1000 may also include a disk or optical drive unit 1006 .
- the disk drive unit 1006 may include a computer-readable medium 1022 in which one or more sets of instructions 1024 , e.g. software, can be embedded. Further, the instructions 1024 may perform one or more of the methods or logic as described herein. The instructions 1024 may reside completely, or at least partially, within the memory 1004 and/or within the processor 1002 during execution by the computer system 1000 .
- the memory 1004 and the processor 1002 also may include computer-readable media as discussed above.
- the present disclosure contemplates a computer-readable medium 1022 that includes instructions 1024 or receives and executes instructions 1024 responsive to a propagated signal; so that a device connected to a network 235 may communicate voice, video, audio, images or any other data over the network 235 .
- the instructions 1024 may be implemented with hardware, software and/or firmware, or any combination thereof. Further, the instructions 1024 may be transmitted or received over the network 235 via a communication interface 1018 .
- the communication interface 1018 may be a part of the processor 1002 or may be a separate component.
- the communication interface 1018 may be created in software or may be a physical connection in hardware.
- the communication interface 1018 may be configured to connect with a network 235 , external media, the display 1014 , or any other components in system 1000 , or combinations thereof.
- the connection with the network 235 may be a physical connection, such as a wired Ethernet connection or may be established wirelessly as discussed below.
- the additional connections with other components of the system 1000 may be physical connections or may be established wirelessly.
- the servers may communicate with users 120 AA-NN and the revenue generators 110 A-N through the communication interface 1018 .
- the network 235 may include wired networks, wireless networks, or combinations thereof.
- the wireless network may be a cellular telephone network, an 802.11, 802.16, 802.20, or WiMax network.
- the network 235 may be a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to TCP/IP based networking protocols.
- the computer-readable medium 1022 may be a single medium, or the computer-readable medium 1022 may be a single medium or multiple media, such as a centralized or distributed database, and/or associated caches and servers that store one or more sets of instructions.
- the term “computer-readable medium” may also include any medium that may be capable of storing, encoding or carrying a set of instructions for execution by a processor or that may cause a computer system to perform any one or more of the methods or operations disclosed herein.
- the computer-readable medium 1022 may include a solid-state memory such as a memory card or other package that houses one or more non-volatile read-only memories.
- the computer-readable medium 1022 also may be a random access memory or other volatile re-writable memory.
- the computer-readable medium 1022 may include a magneto-optical or optical medium, such as a disk or tapes or other storage device to capture carrier wave signals such as a signal communicated over a transmission medium.
- a digital file attachment to an e-mail or other self-contained information archive or set of archives may be considered a distribution medium that may be a tangible storage medium. Accordingly, the disclosure may be considered to include any one or more of a computer-readable medium or a distribution medium and other equivalents and successor media, in which data or instructions may be stored.
- dedicated hardware implementations such as application specific integrated circuits, programmable logic arrays and other hardware devices, may be constructed to implement one or more of the methods described herein.
- Applications that may include the apparatus and systems of various embodiments may broadly include a variety of electronic and computer systems.
- One or more embodiments described herein may implement functions using two or more specific interconnected hardware modules or devices with related control and data signals that may be communicated between and through the modules, or as portions of an application-specific integrated circuit. Accordingly, the present system may encompass software, firmware, and hardware implementations.
- the methods described herein may be implemented by software programs executable by a computer system. Further, implementations may include distributed processing, component/object distributed processing, and parallel processing. Alternatively or in addition, virtual computer system processing maybe constructed to implement one or more of the methods or functionality as described herein.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Finance (AREA)
- Data Mining & Analysis (AREA)
- Strategic Management (AREA)
- General Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Computational Linguistics (AREA)
- Accounting & Taxation (AREA)
- Development Economics (AREA)
- General Business, Economics & Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Game Theory and Decision Science (AREA)
- Marketing (AREA)
- Economics (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
- The present description relates generally to a system and method, generally referred to as a system, for associating data items with context, and more particularly, but not exclusively, to building data stores of contextually relevant data items.
- The mobile phone may be increasingly important as an information and content access device. Currently there may be twice as many mobile communication devices as personal computers. Mobile operators may be increasingly looking to high value data services as a way to overcome the continuing voice average revenue per user (“ARPU”) decline. As consumer adoption of wireless technology continues to increase, advertising via mobile devices may become an important part of all integrated data communications strategies.
- A system is disclosed for providing building a data store of contextually relevant data items. The system may include a processor, a memory and an interface. The memory may be operatively connected to the processor and the interface and may store an association between a descriptor of an action performed by a user, a spatial attribute of the action, a temporal attribute of the action, a social attribute of the action and a topical attribute of the action. The interface may provide contextually relevant data items. The processor may identify the action performed by the user and may determine the spatial, temporal, social and topical attributes of the action. The spatial attribute of the action may relate to the location of the user. The temporal attribute of the action may relate to the time when the user performed the action. The social attribute of the action may relate to a social relation of the user. The topical attribute may relate to a topic of interest to the user. The processor may store an association between a descriptor of the action performed by the user, the spatial attribute of the action, the temporal attribute of the action, the social attribute of the action and the topical attribute of the action in the memory. The processor may use the stored association to provide a contextually relevant data item via the interface.
- Other systems, methods, features and advantages will be, or will become, apparent to one with skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description, be within the scope of the embodiments, and be protected by the following claims and be defined by the following claims. Further aspects and advantages are discussed below in conjunction with the description.
- The system and/or method may be better understood with reference to the following drawings and description. Non-limiting and non-exhaustive descriptions are described with reference to the following drawings. The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating principles. In the figures, like referenced numerals may refer to like parts throughout the different figures unless otherwise specified.
-
FIG. 1 is a block diagram of a general overview of a system for associating data items with context. -
FIG. 2 is block diagram of a simplified view of a network environment implementing the system ofFIG. 1 or other systems for associating data items with context. -
FIG. 3 is a block diagram of an implementation of the system ofFIG. 1 or other systems for associating data items with context. -
FIG. 4 is a block diagram of a workflow of the system ofFIG. 1 or other systems for associating data items with context. -
FIG. 5 is an illustration of exemplary contextual attributes associated with a user click action in the system ofFIG. 1 , or other systems for associating data items with context. -
FIG. 6 is a flowchart illustrating operations of associating data items with context in the system ofFIG. 1 , or other systems for associating data items with context. -
FIG. 7 is a flowchart illustrating operations of building a contextual data store in the system ofFIG. 1 , or other systems for associating data items with context. -
FIG. 8 is a flowchart illustrating operations of generating contextual models in the system ofFIG. 1 , or other systems for associating data items with context. -
FIG. 9 is a flowchart illustrating operations of providing contextually relevant search results in the system ofFIG. 1 or other systems for associating data items with context. -
FIG. 10 is an illustration a general computer system that may be used in a system for associating data items with context. - A system and method, generally referred to as a system, relate to associating data items with context, and more particularly, but not exclusively, to building data stores of contextually relevant data items. The principles described herein may be embodied in many different forms.
- The system may allow a service provider to provide search results and/or advertisements that are relevant to the context of a query. The context may be determined by one or more contextual attributes, such as a spatial attribute, a temporal attribute, a social attribute, or a topical attribute. The system may allow the service provider to retrieve the contextually relevant search results and rank the search results based on their relevancy to the context of the search query. The search results most relevant to the context of the search query may be provided to the user. The system may provide an advantage over prior art systems by incorporating the context specific to an individual query into the selection of search results, thereby providing more relevant search results to the user.
- The system may allow a service provider to build a data store of contextual user behavior data. The data store may include data items describing the actions of a user and the context the action was performed in. Each data item describing an action of the user may be associated with one or more contextual attributes describing the context. The contextual attributes may include a spatial attribute, a temporal attribute, a social attribute and a topical attribute. The spatial attribute may describe the location of the user while performing the action. The temporal attribute may describe the time when the user performed the action. The social attribute may describe the behavior of users socially connected to the user. The topical attribute may describe topics of interest the user has recently expressed interest in. The system may store an association between the action and the contextual attributes in a contextual user behavior data store. The user behavior data store may then be used to determine and provide contextually relevant data items.
- The system may allow a service provider to build contextual user behavior models. Each model may reflect the behavior of a user when the user's context falls within the context represented by the model. The system may build a model for each context identified in a user behavior data store. The models may be used to provide data to a user which is relevant to the context of the user.
- The system may allow a service provider to provide contextually relevant search results. The system may build a data store of contextual user behavior data and may generate contextual user behavior models based on the data store. The system may receive a search query from a user and may determine the context in which the query was performed. The system may retrieve the contextual model correlating to the context in which the query was performed. The contextual model may be used to determine the search results relating to the search query which are relevant to the context the query was performed in. The search results most relevant to the context may be provided to the user.
-
FIG. 1 provides a general overview of asystem 100 for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
system 100 may include one ormore revenue generators 110A-N, such as mobile advertisers, aservice provider 130, such as a portal, one or more mobile network operators (“MNOs”) 115A-N, more commonly referred to as mobile carriers, or simply carriers, and one or more users 120AA-NN, such as mobile subscribers or consumers. Theservice provider 130 may implement an advertising campaign management system incorporating an auction based and/or non-auction based advertisement serving system. - The
revenue generators 110A-N may pay theservice provider 130 to serve, or display, advertisements of their goods or services, such as mobile advertisements, to the users 120AA-NN, such as over mobile messaging, mobile web, the Internet, or generally any venue for displaying advertisements. The advertisements may include sponsored listings, banners ads, popup advertisements, mobile messaging advertisements, or generally any way of attracting the users 120AA-NN to the web site or mobile site of therevenue generators 110A-N. The users 120AA-NN may utilize the services of theservice provider 130 through web applications, mobile applications, such as mobile messaging applications, or standalone applications. - The
service provider 130 may maintain a mobile portal and/or a web portal, such as a search site, where theservice provider 130 may display advertisements of therevenue generators 110A-N to the users 120AA-NN. In the case of a mobile portal, theservice provider 130 may share revenue with the mobile network operators MNOs 115A-N of the users 120AA-NN for displaying advertisements of therevenue generators 110A-N via their mobile networks. Alternatively or in addition theservice provider 130 may share revenue with individual publishers for displaying advertisements of therevenue generators 110A-N on their mobile and/or web sites. - The
MNOs 115A-N may provide a mobile network to the users 120AA-NN which may provide a variety of services to the users 120AA-NN, such as the ability to send and receive phone calls, send and receive mobile messages, to access the internet and/or the mobile web, or generally any service that may be implemented on a mobile device. TheMNOs 115A-N may store data describing the users 120AA-NN, such as billing addresses, call histories, messaging histories, or generally any data regarding the users 120AA-NN that may be available to theMNOs 115A-N. - The
service provider 130 may provide an application programming interface (“API”) to theMNOs 115A-N to allow theMNOs 115A-N to access the mobile search and mobile advertising services of theservice provider 130. TheMNOs 115A-N may make a call to the API to retrieve search results or mobile advertisements from theservice provider 130. - The amount the
revenue generators 110A-N may pay theservice provider 130 for displaying advertisements may be based on one or more factors. These factors may include impressions, click throughs, conversions, and/or generally any metric relating to the advertisement and/or the behavior of the users 120AA-NN. The impressions may refer to the number of times an advertisement may have been displayed to the users 120AA-NN. The click throughs may refer to the number of times the users 120AA-NN may have clicked through an advertisement to a web site, mobile web site or mobile landing page of one of therevenue generators 110A-N, such as therevenue generator A 110A. The conversions may refer to the number of times a desired action was taken by the users 120AA-NN after clicking though to a web site of therevenue generator A 110A. The desired actions may include submitting a sales lead, making a purchase, viewing a key page of the site, downloading a whitepaper, and/or any other measurable action. If the desired action is making a purchase, then therevenue generator A 110A may pay the service provider 130 a percentage of the purchase. - The users 120AA-NN may also be consumers of goods or services who may be searching for a business, such as the business of one of the
revenue generators 110A-N. The users 120AA-NN may be associated with one another via a social relation to one or more of the other users 120AA-NN. The social relation may be an explicit relationship, such as a relationship coded in a social network. Alternatively or in addition the social relation may be an implicit, implied, or inferred relationship, such as a relationship based on the actual number, frequency, length, or subject matter of contacts between users. The social relation may associate the users 120AA-NN who share a common interest. Alternatively or in addition the users 120AA-NN may be linked based on shared demographics. For example, all of the users 120AA-NN of the same age range, and/or gender, may be associated together. - Alternatively or in addition the users 120AA-NN may be machines or other servers, such as the
third party server 250. The users 120AA-NN may need a user identifier or identification (“user ID”) to access the services of theservice provider 130. In order to obtain a user ID the users 120AA-NN may need to supply information describing themselves to theservice provider 130, such as the location, gender, or age of the users 120AA-NN, or generally any information that may be required for the users 120AA-NN to utilize the services provided by theservice provider 130. - The
service provider 130 may collect user behavior data from the users 120AA-NN, such as queries searched for by the users 120AA-NN, links clicked on by the users 120AA-NN and/or any user interactions with the services provided by theservice provider 130. Theservice provider 130 may associate each piece of user behavior data with one or more contextual attributes. The contextual attributes may associate a subject matter or other keyword that designates an interest, activity or association of the user with that subject, topic or real-world object. The contextual attributes may describe the context at the time the users 120AA-NN generated the user behavior data. Alternatively or in addition the contextual attributes may be relative to other users or other queries. The contextual attributes may include a spatial attribute, a temporal attribute, a topical attribute, and a social attribute. The spatial attribute may describe the location of the user AA 120AA. The temporal attribute may describe the time when the user AA 120A interacted with theservice provider 130. The topical attribute may describe the topics that the user AA 120AA has recently showed interest in. Alternatively or in addition the topical attribute may represent the subject matter of the query. The social attribute may describe the topics that the users 120AA-NN in a social relationship with the user AA 120AA have shown interest in. Alternatively or in addition the social attribute may represent an association or relation of the user with other users. - The
service provider 130 may receive a search request from a user AA 120AA and provide contextually relevant search results and/or advertisements to the user AA 120AA. Contextually relevant data may be determined by analyzing user behavior data sharing the same contextual attributes as the current search query. The user behavior data sharing the same contextual attributes as the current search query may be used to determine which search results and/or advertisements the user AA 120AA may be most likely to click on. The search results and/or advertisements the user AA 120AA may be most likely to click on may be the most relevant search results and/or advertisements. - In the
system 100, therevenue generators 110A-N may interact with theservice provider 130, such as via a web application. Therevenue generators 110A-N may send information, such as billing, website or mobile site and advertisement information, to theservice provider 130 via the web application. The web application may include a web browser or other application such as any application capable of displaying web content. The application may be implemented with a processor such as a personal computer, personal digital assistant, mobile phone, or any other machine capable of implementing a web application. - The users 120AA-NN may also interact individually with the
service provider 130, through themobile network operators 115A-N, such as via a mobile phone or any mobile device capable of communicating with themobile network operators 115A-N. The users 120AA-NN may interact with theservice provider 130 via a mobile web based application, a mobile standalone application, or any application capable of running on a mobile device. Theservice provider 130 may communicate data to therevenue generators 110A-N over a network and to the users 120AA-NN over a network via theMNOs 115A-N. The following examples may refer to arevenue generator A 110A as an online advertiser or mobile advertiser; however thesystem 100 may apply to anyrevenue generators 110A-N who may wish to serve advertisements over mobile devices. - A
revenue generator A 110A who is an advertiser may maintain one or more accounts with theservice provider 130. For each account therevenue generator A 110A may maintain one or more campaigns. For each campaign therevenue generator A 110A may maintain one or more listings. A listing may include a keyword, an advertisement title, an advertisement description, a bid amount and a network address, if any, such as a uniform resource locator (“URL”). A listing may represent an association between a keyword and an advertisement. - Alternatively or in addition the listing may be associated with a context descriptor. The context descriptor may describe a context surrounding a user AA 120AA when the user AA 120AA searches for the query. The context descriptor may include one or more attributes, such as a spatial attribute, a temporal attribute, a social attribute or a topical attribute. The spatial attribute may describe the location of the user AA 120AA when the user AA 120AA searches for the query. The temporal attribute may describe a time, or time of day, when the user AA 120AA searches for the query. The social attribute may describe an item of interest to user 120BB-N within a social relation of the user AA 120AA searching for the query. The topical attribute may describe a topical interest of the user AA 120AA searching for the query. A
revenue generator A 110A may associate different versions of the advertisements for different contexts. For example, therevenue generator A 110A may wish to associate a different advertisement with a query depending on whether the user AA 120AA searches for the query in the evening or in the morning. - The keywords may represent one or more search terms that the revenue generator A 110A wishes to associate with their advertisement. The advertisement title may represent the data the revenue generator A 110A wishes to be displayed to a user AA 120AA. The network address may represent the link the revenue generator A 110A wishes a user AA 120AA to be directed to upon clicking on the advertisement of the revenue generator A 110A, such as the home page of the
revenue generator A 110A. The bid amount may represent a maximum amount therevenue generator A 110A may be willing to pay each time a user AA 120AA may click on the advertisement of therevenue generator A 110A or each time the advertisement of therevenue generator A 110A may be shown to a user AA 120AA, such as in a mobile message. More detail regarding the aspects of mobile advertising systems, as well as their structure, function and operation, can be found in commonly owned U.S. patent application Ser. No. 11/712,276, filed on Feb. 28, 2007, entitled, “SYSTEM FOR SERVING ADVERTISEMENTS OVER MOBILE DEVICES”, which is hereby incorporated herein by reference in its entirety. The systems and methods herein associated with mobile advertising systems may be practiced in combination with methods and systems described in the above-identified patent application incorporated by reference. - In operation, the user AA 120AA may search for a query via a search service provided by the
service provider 130. Theservice provider 130 may determine the contextual attributes at the time the user AA 120AA performs the search. Theservice provider 130 may retrieve historical user behavior data, such as historical user click data, sharing the same contextual attributes as the search of the user AA 120AA. The historical user click data may be represented by a model of click data of users 120AA-NN sharing the same contextual attributes as the user AA 120AA. The model may take the query searched for by the user AA 120AA as an input and may output the search results and/or advertisements most relevant to the user AA 120AA. Alternatively the model may take the query search for by the user AA 120AA and the contextual attributes as inputs. - More detail regarding the aspects of auction-based systems, as well as the structure, function and operation of the
service provider 130, as mentioned above, can be found in commonly owned U.S. patent application Ser. No. 10/625,082, filed on Jul. 22, 2003, entitled, “TERM-BASED CONCEPT MARKET”; U.S. patent application Ser. No. 10/625,000, file on Jul. 22, 2003, entitled, “CONCEPT VALUATION IN A TERM-BASED CONCEPT MARKET” filed on Jul. 22, 2003; U.S. patent application Ser. No. 10/625,001, filed on Jul. 22, 2003, entitled, “TERM-BASED CONCEPT INSTRUMENTS”; and U.S. patent application Ser. No. 11/489,386, filed on Jul. 18, 2006, entitled, “ARCHITECTURE FOR AN ADVERTISEMENT DELIVERY SYSTEM,” all of which are hereby incorporated herein by reference in their entirety. The systems and methods herein associated with ad campaign management may be practiced in combination with methods and systems described in the above-identified patent applications incorporated by reference. - Furthermore, the
service provider 130 may generate reports based on the data collected from the users 120AA-NN and communicate the reports to therevenue generators 110A-N to assist therevenue generators 110A-N in measuring the effectiveness of their advertising. The reports may indicate the number of times the users 120AA-NN viewed a mobile advertisement of therevenue generators 110A-N, the number of times a mobile advertisement of therevenue generators 110A-N was clicked on by the users 120AA-NN, the contextual attributes of the users 120AA-NN, or generally any information useful to therevenue generators 110A-N. There may be a separate report for eachMNO 115A-N the advertisement of the revenue generator A 110A was displayed on. Alternatively or in addition the reports may be segmented based on one or more of the contextual attributes. The reports may also generally indicate any data that may assist therevenue generators 110A-N in measuring the effectiveness of their mobile advertising campaigns. -
FIG. 2 provides a simplified view of a network environment implementing asystem 200 for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
system 200 may include one or more web applications, standalone applications andmobile applications 210A-N, which may be collectively or individually referred to as client applications of therevenue generators 110A-N. Thesystem 200 may also include one or more mobile applications, such as mobile messaging applications and/or mobile browsers, which may be running on one or more mobile devices 220AA-NN. Thesystem 200 may also include one or moreMNO gateway servers 215A-N, anetwork 230, anetwork 235, theservice provider server 240, athird party server 250, and anadvertising services server 260. - Some or all of the
advertisement services server 260,service provider server 240, and third-party server 250 may be in communication with each other by way ofnetwork 235 and may be the system or components described below inFIG. 10 . Theadvertisement services server 260, third-party server 250 andservice provider server 240 may each represent multiple linked computing devices. Multiple distinct third party servers, such as the third-party server 250, may be included in thesystem 200. The third-party server 250 may be anMNO gateway server 215A-N or a server associated with, or in communication with anMNO gateway server 215A-N. - The
networks network 230 may include the Internet and may include all or part ofnetwork 235;network 235 may include all or part ofnetwork 230. Thenetworks networks system 200, or the sub-networks may restrict access between the components connected to thenetworks network 235 may be regarded as a public or private network connection and may include, for example, a virtual private network or an encryption or other security mechanism employed over the public Internet, or the like. - The
revenue generators 110A-N may use aweb application 210A,standalone application 210B, or amobile application 210N, or any combination thereof, to communicate to theservice provider server 240, such as via thenetworks service provider server 240 may communicate to therevenue generators 110A-N via thenetworks mobile applications 210A-N. - The users 120AA-NN may use a mobile application running on a mobile device 220AA-220NN, such as a mobile web browser, to communicate with the
service provider server 240, via theMNO gateway servers 215A-N and thenetworks service provider server 240 may communicate to the users 120AA-NN via thenetworks MNO gateway servers 215A-N, through the mobile devices 220AA-NN. - The web applications, standalone applications, mobile applications and
mobile devices 210A-N, 220AA-NN may be connected to thenetwork 230 in any configuration that supports data transfer. This may include a data connection to thenetwork 230 that may be wired or wireless. Any of the web applications, standalone applications andmobile applications 210A-N, may individually be referred to as a client application. Theweb application 210A may run on any platform that supports web content, such as a web browser or a computer, a mobile phone, personal digital assistant (“PDA”), pager, network-enabled television, digital video recorder, such as TIVO®, automobile and/or any appliance capable of data communications. - The
standalone applications 210B may run on a machine that may have a processor, memory, a display, a user interface and a communication interface. The processor may be operatively connected to the memory, display and the interfaces and may perform tasks at the request of thestandalone application 210B or the underlying operating system. The memory may be capable of storing data. The display may be operatively connected to the memory and the processor and may be capable of displaying information to therevenue generator B 110B. The user interface may be operatively connected to the memory, the processor, and the display and may be capable of interacting with arevenue generator B 110B. The communication interface may be operatively connected to the memory, and the processor, and may be capable of communicating through thenetworks service provider server 240,third party server 250 andadvertising services server 260. Thestandalone application 210B may be programmed in any programming language that supports communication protocols. These languages may include: SUN JAVA, C++, C#, ASP, SUN JAVASCRIPT, asynchronous SUN JAVASCRIPT, or ADOBE FLASH ACTIONSCRIPT, amongst others. - The
mobile application 210N may run on any mobile device which may have a data connection. Themobile applications 210N may be aweb application 210A, astandalone application 210B, a mobile messaging application, a mobile browser, or a microbrowser. The mobile devices 220AA-NN may be one of a broad range of electronic devices which may include mobile phones, PDAs, and laptops and notebook computers. The mobile devices 220AA-NN may have a reduced feature set, such as a smaller keyboard and/or screen, and may be incapable of supporting a traditional web search. - The data connection of the mobile devices 220AA-NN may be a cellular connection, such as a GSM/GPRS/WCDMA connection, a wireless data connection, an internet connection, an infra-red connection, a Bluetooth connection, or any other connection capable of transmitting data. The data connection may be used to connect directly to the
network 230, or to connect to thenetwork 230 through theMNO gateway servers 215A-N. - The
MNO gateway servers 215A-N may control the access the mobile devices 220AA-NN may have to the network. TheMNO gateway servers 215A-N may also control the technology supporting the respective mobile devices 220AA-NN. This may affect aspects of the user experience, such as signal strength and availability, speed and billing mechanisms. For example, the MNOgateway server A 215A may only allow the users 120AA-NA access to content provided by partners of theMNO A 115A. Furthermore, theMNO gateway servers 215A-N may only allow users 120AA-NN access to data in a specific format, such as WML, XHTML, NTT DOCOMO IMODE HTML, or cHTML. Alternatively or in addition, the mobile devices 220AA-NN may only support one of the aforementioned formats. - The
service provider server 240 may include one or more of the following: an application server, a data source, such as a database server, a middleware server, and an advertising services server. One middleware server may be a mobile commerce platform, such as the YAHOO! SUSHI platform, which may properly encode data, such as mobile pages or mobile advertisements, to the formats specific to theMNO gateway servers 215A-N. Theservice provider server 240 may co-exist on one machine or may be running in a distributed configuration on one or more machines. Theservice provider server 240 may collectively be referred to as the server. Theservice provider server 240 may receive requests from the users 120AA-NN and therevenue generators 110A-N and may serve mobile pages to the users 120AA-NN and web pages and/or mobile pages to therevenue generators 110A-N based on their requests. - The
third party server 250 may include one or more of the following: an application server, a data source, such as a database server, a middleware server, and an advertising services server. Thethird party server 250 may co-exist on one machine or may be running in a distributed configuration on one or more machines. Theadvertising services server 260 may provide a platform for the inclusion of advertisements in pages, such as web pages or mobile pages. Theadvertisement services server 260 may be used for providing mobile advertisements that may be displayed to the users 120AA-NN. - The
service provider server 240, thethird party server 250 and theadvertising services server 260 may be one or more computing devices of various kinds, such as the computing device inFIG. 10 . Such computing devices may generally include any device that may be configured to perform computation and that may be capable of sending and receiving data communications by way of one or more wired and/or wireless communication interfaces. Such devices may be configured to communicate in accordance with any of a variety of network protocols, including but not limited to protocols within the Transmission Control Protocol/Internet Protocol (“TCP/IP”) protocol suite. For example, theweb application 210A may employ HTTP to request information, such as a web page, from a web server, which may be a process executing on theservice provider server 240 or the third-party server 250. - There may be several configurations of database servers, application servers, middleware servers and advertising services servers included in the
service provider server 240 or thethird party server 250. Database servers may include MICROSOFT SQL SERVER, ORACLE, IBM DB2 or any other database software, relational or otherwise. The application server may be APACHE TOMCAT, MICROSOFT IIS, ADOBE COLDFUSION, YAPACHE or any other application server that supports communication protocols. The middleware server may be any middleware that connects software components or applications. The application server on theservice provider server 240 or thethird party server 250 may serve pages, such as web pages to the users 120AA-NN and therevenue generators 110A-N. The advertising services server may provide a platform for the inclusion of advertisements in pages, such as web pages. Theadvertising services server 260 may also exist independent of theservice provider server 240 and thethird party server 250. - The
networks networks networks networks -
FIG. 3 illustrates a block diagram of animplementation 300 of the system ofFIG. 1 or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
implementation 300 may include a user AA 120AA, a mobile device 220AA, anetwork 230, aservice provider server 240, acontextual data store 320, amodels data store 330, and aresults data store 340. Theservice provider server 240 may include aninterface 310, aninput processor 312, atraining processor 316 and aranking processor 314. Theinterface 310 may allow theservice provider server 240 to communicate with the mobile device 220AA over thenetwork 230. Theprocessors - In operation, the user AA 120AA may interact with a service of the
service provider server 240 via the mobile device 220AA over thenetwork 230. The mobile device 220AA may communicate with theservice provider server 240 via theinterface 310. Theinterface 310 may receive an indication of an action performed by the user AA 120AA, such as when the user AA 120AA clicks on a search result after searching for a query. Theinterface 310 may communicate the action to theinput processor 312. Theinput processor 312 may determine the contextual attributes associated with the action, such as a spatial attribute, a temporal attribute, a topical attribute and a social attribute. Theinput processor 312 may determine the spatial attribute based on a positioning system implemented by the mobile device 220AA, and/or based on a network address of the mobile device 220AA. Theinput processor 312 may store an association between the contextual attributes, the query searched for by the user AA 120AA, and the search result clicked on by the user AA 120AA in thecontextual data store 320. Theinput processor 312 may then provide a forwarding network address associated with the search result clicked on to the mobile device of the user AA 120AA. - The
training processor 316 may generate one or more models representing the behavior of users 120AA-NN within a given context based on the data stored in thecontextual data store 320. Thetraining processor 316 may create a model for each context represented in thecontextual data store 320, or may create a model for the most commonly represented contexts in thecontextual data store 320. Thetraining processor 316 may analyze the historical click data of the users 120AA-NN within a given context to generate a model for each context capable of determining the most relevant search results and/or advertisements for a user AA 120AA within the context. - The user AA 120AA may perform a search for a query via a service provided by the
service provider server 240. Theservice provider server 240 may receive the search query via theinterface 310. Theinterface 310 may communicate the search query to theinput processor 312. Theinput processor 312 may determine the context in which the search query was performed. Theinput processor 312 may retrieve the model from themodels data store 330 representing the context of the user AA 120AA. Theinput processor 312 may provide the model and the search query to theranking processor 314. Theranking processor 314 may use the model to retrieve the search results in theresults data store 340 which are most relevant to the context of the user AA 120AA. Alternatively or in addition theranking processor 314 may use the model to retrieve advertisements relevant to the context of the user AA 120AA from theresults data store 340. Theranking processor 314 may provide the search results most relevant to the context of the user AA 120AA to theinterface 310. The number of search results provided to theinterface 310 may be dependent on the display capacity of the mobile device 220AA of the user AA 120AA. Theinterface 310 may provide the results to the mobile device 220AA via thenetwork 230. -
FIG. 4 illustrates a block diagram of a workflow of the system ofFIG. 1 or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
workflow 300 of thesystem 100 may include thecontextual data store 320, thetraining processor 316, themodels data store 330, theinput processor 312, the rankingprocessor 314, the user AA 120AA, and the mobile device 220AA. Theworkflow 100 of thesystem 100 may start with thecontextual data store 320. Thecontextual data store 320 may include data describing the actions of the users 120AA-NN, such as user click data. Each action may be associated with one or more contextual attributes, such as a spatial attribute, a temporal attribute, a social attribute, and a topical attribute. - The data from the
contextual data store 320 may be provided to thetraining processor 316. Thetraining processor 316 may analyze the data in thecontextual data store 320 to generate a model for each of the contexts represented in the contextual data store. The models may reflect the historical behavior of the users 120AA-NN within the context represented by each model. Thetraining processor 316 may then store the models in themodels data store 330. A model may be retrieved from themodels data store 330 by theinput processor 312 when a user AA 120AA searches for a search query via the mobile device 220AA. Theinput processor 312 may determine the context the search query was performed in, and may retrieve the model corresponding to the context. Theinput processor 312 may provide the model retrieved from themodels data store 330, and the query searched for by the user AA 120AA, to theranking processor 314. - The
ranking processor 314 may use the model to select the search results and or advertisements most relevant to the context of the user AA 120AA determined by theinput processor 312 for the search query. Theranking processor 314 may rank the search results based on their relevancy, in the model, to the search query and may provide the ranked search results to the mobile device 220AA of the user AA 120AA. -
FIG. 5 illustrates exemplary contextual attributes associated with a user click action in the system ofFIG. 1 , or other systems for associating data items with context. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
system 100 may determine the context of auser action 520 when the user AA 120AA performs an action. An association between the context and theuser action 520 may be stored in thecontextual data store 320. The context of auser action 520 may be based on asocial attribute 522, atopical attribute 524, atemporal attribute 526, and alocal attribute 528. In the case of auser action 520 consisting of a user AA 120AA clicking on a search result, thesystem 100 may also store an association with the search query which generated the search result. - The
social attribute 522 of theuser action 520 may describe the recent actions of the other users 120BB-NN associated with the user AA 120AA, such as users 120BB-NN associated with the user AA 120AA through a social relation. The social relations of the user AA 120AA may be determined based on a service offered by theservice provider 130 or by athird party server 250. Alternatively or in addition thesocial attribute 522 may describe the behavior of the users 120BB-NN sharing a social relation with the user AA 120AA. The behavior of the users 120BB-NN may include expressing interest in an item, such as by reading a news article, clicking on search results, visiting places, buying items, connecting with other people, participating in groups and/or group activities, or generally expressing interest in any topical, spatial, or social issues and items. Thesocial attribute 522 may be determined by analyzing the click data of the users 120BB-NN associated with the user AA 120AA. - The
topical attribute 524 of theuser action 520 may describe the recent actions of the user AA 120AA. The recent actions of the user AA 120AA may include items recently of interest to the user AA 120AA, such as news articles read by the user AA 120AA, search results clicked on by the user AA 120AA, or generally any items the user AA 120AA previously expressed interest in. Thetopical attribute 524 may be determined by analyzing the click data of the user AA 120AA. - The
social attributes 522 and thetopical attributes 524 may be selected from a group of categories. The categories may generally relate to topics of interests to the users 120AA-NN, such as sports, news, music, video, or generally any topic of interest to users 120AA-NN. The topics may be determined based on metrics measuring general topics of interest to the users 120AA-NN. Alternatively or in addition the categories may contain more specific sub-categories. For example, the category of sports may have subcategories such as football, baseball, basketball, hockey, or generally any sport that may be of interest to the users 120AA-NN. Thesystem 100 may analyze the content of the pages visited by the users 120AA-NN to determine which categories the website relates to. Alternatively or in addition athird party server 250 may provide categories for each web site, or may determine the category a website relates to. - The
temporal attribute 526 of theuser action 520 may be the time the user AA 120AA performed theuser action 520. For example, in the case of a click action, thetemporal attribute 526 may be the time the user AA 120AA clicked on a link. Thetemporal attribute 526 may be determined based on a timestamp associated with the action performed by the user AA 120AA. - The
spatial attribute 528 of auser action 520 may be the location of the user AA 120AA when the user AA 120AA performs theuser action 520. The location of the user AA 120AA may be determined by a positioning system implemented by the mobile device 220AA, such as a global positioning system, a cell phone tower triangulation system, a wireless internet signal triangulation system, or generally any system capable of determining the location of a user AA 120A. Alternatively or in addition the location of the user AA 120AA may be determined based on the network address associated with the mobile device 220AA, may be determined based on the content of the search query, or generally maybe determined based on other analytical methods. Alternatively or in addition the location of the user AA 120AA may be determined based on a known location of a user who is known to be within a close proximity of the user AA 120AA. -
FIG. 6 is a flowchart illustrating operations of associating data items with context in the system ofFIG. 1 , or other systems for associating data items with context. Atblock 610 theservice provider 130 stores data describinguser actions 520, and thecontextual data user action 520, in thecontextual data store 320. Theservice provider 130 may store data describing theuser actions 520 over a period of time before generating the models. Alternatively theservice provider 130 may add data to thecontextual data store 320 until thecontextual data store 320 contains enough data to generate reliable models. Atblock 620 thetraining processor 316 generates models for each of the contexts stored in thecontextual data store 320. For example, a model of a given context may contain all of the user action data associated with the context. The models may be stored in themodels data store 330. Alternatively or in addition thesystem 100 may generate models for contexts that only share one of thecontextual attributes spatial attribute 528. - At
block 630 thesystem 100 may receive a search query from one of the users 120AA-NN, such as the user AA 120AA. Atblock 640 thesystem 100 may identify thecontextual attributes block 650 thesystem 100 may select a model from themodels data store 330 that corresponds to the contextual attributes of the search query identified inblock 640. The selected data model may correlate to one or more of the contextual attributes associated with the search query. Atblock 660 theranking processor 314 may use the selected model to rank the search results retrieved for the search query. The selected model may allow theranking processor 314 to incorporate the context of the search query into the ranking of the search results. The search results may be paid advertisements listings, unpaid search listings, or a combination of paid advertisement listings and unpaid search listings. Atblock 670 theservice provider 130 may provide the ranked results to the user AA 120AA. -
FIG. 7 is a flowchart illustrating operations of building a contextual data store in the system ofFIG. 1 , or other systems for associating data items with context. Atblock 710 theservice provider 130 identifies an action of one of the users 120AA-NN, such as the user AA 120AA clicking on a search result. Atblock 720 theservice provider 130 determines thespatial attribute 528 of theuser action 520. Thespatial attribute 528 may describe the location of the user AA 120AA. The location of the user AA 120AA may be determined by a positioning system implemented by the mobile device 220AA of the user AA 120AA, or by analyzing data associated with the mobile device 220AA, such as the network address of the mobile device 220AA. Atblock 730 theservice provider 130 may determine thetemporal attribute 526 of theuser action 520. Thetemporal attribute 526 may describe the time when the user AA 120AA performed the action. - At
block 740 theservice provider 130 may determine thesocial attribute 522 of theuser action 520. Thesocial attribute 522 may describe the interests of the users 120BB-NN associated with the user AA 120AA, such as through a social relation. Atblock 750 theservice provider 130 may determine thetopical attribute 524 of theuser action 520. Thetopical attribute 524 may describe the topics the user AA 120AA has recently expressed interest in, such as a category describing web sites recently visited by the user AA 120AA. - At
block 760 theservice provider 130 may store an association between theuser action 520, in this case the search result clicked on by the user AA 120AA, thespatial attribute 528, thetemporal attribute 526, thesocial attribute 522 and thetopical attribute 524 in thecontextual data store 320. In the case of auser action 520 including a user AA 120AA clicking on a search result after searching for a search query, theservice provider 130 may also store an association with the search query. Atblock 770 theservice provider 130 may use the stored association to provide contextually relevant data. For example, theservice provider 130 may use the stored association to determine a search result contextually relevant to a search query. -
FIG. 8 is a flowchart illustrating operations of generating contextual models in the system ofFIG. 1 , or other systems for associating data items with context. Atblock 810 theservice provider 130 may determine data items associated with contextual data, such asuser actions 520 associated withcontextual attributes contextual data store 320. Atblock 820 thetraining processor 316 may generate a model for each of the contexts represented in thecontextual data store 320. For example, a model may consist of the data describing theuser actions 520 associated with the context represented by the model. Atblock 830 theservice provider 130 may store the models in themodels data store 330. Atblock 840 theservice provider 130 may use a model to provide a contextually relevant data item, such a contextually relevant search result. In the case of the contextually relevant search result, a model sharing a context with a query search may take the query search as an input and may output an indication of the search results contextually relevant to the query search. -
FIG. 9 is a flowchart illustrating operations of providing contextually relevant search results in the system ofFIG. 1 or other systems for associating data items with context. Atblock 910 theservice provider 130 may receive a search query from one of the users 120AA-NN, such as the user AA 120AA. Atblock 920 theservice provider 130 may determine the location of the user AA 120AA. The location of the user AA 120AA may be retrieved from a positioning system implemented by the mobile device 220AA of the user AA 120AA. Alternatively or in addition the location of the user may be determined based on the network address associated with the mobile device 220AA of the user AA 120AA or by other analytical methods. Atblock 930 theservice provider 130 may determine the time the search query was received from the user AA 120AA, such as through a timestamp associated with receiving the search query. Atblock 940 theservice provider 130 may determine a social context of the search query. The service provider may determine any social networks the user AA 120AA is associated with and/or any demographic groups the user AA 120AA belongs to. The service provider may determine any social relationships of the user AA 120AA and/or any demographic groups the user AA 120AA belongs to. Theservice provider 130 may then determine the topics recently searched for by other users 120BB-NN associated with the user AA 120AA. - At
block 950 theservice provider 130 may determine the recent topics of interests of the user AA 120AA. The recent topics of interest may correspond to the links recently clicked on by the user AA 120AA. Atblock 960 theservice provider 130 may identify the search results in that are associated with the determined contextual attributes. Atblock 970 theservice provider 130 may determine the most relevant search result. The most relevant search result may be the search result which was most frequently clicked on after performing a search sharing the contextual attributes of the current search. Alternatively or in addition the most relevant search result may be based on one or more other factors, such as in the case of advertisements the amount bid on the advertisement. Atblock 980 thesystem 100 may provide the most relevant search result to the mobile device 220AA of the user AA 120AA. Alternatively or in addition the number of most relevant search results provided to the mobile device 220AA may depend on the number of search results the mobile device 220AA is capable of displaying at a time. -
FIG. 10 illustrates ageneral computer system 1000, which may represent aservice provider server 240, athird party server 250, anadvertising services server 260, atraining processor 316, aninput processor 312, a rankingprocessor 314, or any of the other computing devices referenced herein. Not all of the depicted components may be required, however, and some implementations may include additional components not shown in the figure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Additional, different or fewer components may be provided. - The
computer system 1000 may include a set ofinstructions 1024 that may be executed to cause thecomputer system 1000 to perform any one or more of the methods or computer based functions disclosed herein. Thecomputer system 1000 may operate as a standalone device or may be connected, e.g., using a network, to other computer systems or peripheral devices. - In a networked deployment, the computer system may operate in the capacity of a server or as a client user computer in a server-client user network environment, or as a peer computer system in a peer-to-peer (or distributed) network environment. The
computer system 1000 may also be implemented as or incorporated into various devices, such as a personal computer (“PC”), a tablet PC, a set-top box (“STB”), a personal digital assistant (“PDA”), a mobile device, a palmtop computer, a laptop computer, a desktop computer, a communications device, a wireless telephone, a land-line telephone, a control system, a camera, a scanner, a facsimile machine, a printer, a pager, a personal trusted device, a web appliance, a network router, switch or bridge, or any other machine capable of executing a set of instructions 1024 (sequential or otherwise) that specify actions to be taken by that machine. In a particular embodiment, thecomputer system 1000 may be implemented using electronic devices that provide voice, video or data communication. Further, while asingle computer system 1000 may be illustrated, the term “system” shall also be taken to include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions. - As illustrated in
FIG. 10 , thecomputer system 1000 may include aprocessor 1002, such as, a central processing unit (“CPU”), a graphics processing unit (“GPU”), or both. Theprocessor 1002 may be a component in a variety of systems. For example, theprocessor 1002 may be part of a standard personal computer or a workstation. Theprocessor 1002 may be one or more general processors, digital signal processors, application specific integrated circuits, field programmable gate arrays, servers, networks, digital circuits, analog circuits, combinations thereof, or other now known or later developed devices for analyzing and processing data. Theprocessor 1002 may implement a software program, such as code generated manually (i.e., programmed). - The
computer system 1000 may include amemory 1004 that can communicate via abus 1008. Thememory 1004 may be a main memory, a static memory, or a dynamic memory. Thememory 1004 may include, but may not be limited to computer readable storage media such as various types of volatile and non-volatile storage media, including but not limited to random access memory, read-only memory, programmable read-only memory, electrically programmable read-only memory, electrically erasable read-only memory, flash memory, magnetic tape or disk, optical media and the like. In one case, thememory 1004 may include a cache or random access memory for theprocessor 1002. Alternatively or in addition, thememory 1004 may be separate from theprocessor 1002, such as a cache memory of a processor, the system memory, or other memory. Thememory 1004 may be an external storage device or database for storing data. Examples may include a hard drive, compact disc (“CD”), digital video disc (“DVD”), memory card, memory stick, floppy disc, universal serial bus (“USB”) memory device, or any other device operative to store data. Thememory 1004 may be operable to storeinstructions 1024 executable by theprocessor 1002. The functions, acts or tasks illustrated in the figures or described herein may be performed by the programmedprocessor 1002 executing theinstructions 1024 stored in thememory 1004. The functions, acts or tasks may be independent of the particular type of instructions set, storage media, processor or processing strategy and may be performed by software, hardware, integrated circuits, firmware, micro-code and the like, operating alone or in combination. Likewise, processing strategies may include multiprocessing, multitasking, parallel processing and the like. - The
computer system 1000 may further include adisplay 1014, such as a liquid crystal display (“LCD”), an organic light emitting diode (“OLED”), a flat panel display, a solid state display, a cathode ray tube (“CRT”), a projector, a printer or other now known or later developed display device for outputting determined information. Thedisplay 1014 may act as an interface for the user to see the functioning of theprocessor 1002, or specifically as an interface with the software stored in thememory 1004 or in thedrive unit 1006. - Additionally, the
computer system 1000 may include aninput device 1012 configured to allow a user to interact with any of the components ofsystem 1000. Theinput device 1012 may be a number pad, a keyboard, or a cursor control device, such as a mouse, or a joystick, touch screen display, remote control or any other device operative to interact with thesystem 1000. - The
computer system 1000 may also include a disk oroptical drive unit 1006. Thedisk drive unit 1006 may include a computer-readable medium 1022 in which one or more sets ofinstructions 1024, e.g. software, can be embedded. Further, theinstructions 1024 may perform one or more of the methods or logic as described herein. Theinstructions 1024 may reside completely, or at least partially, within thememory 1004 and/or within theprocessor 1002 during execution by thecomputer system 1000. Thememory 1004 and theprocessor 1002 also may include computer-readable media as discussed above. - The present disclosure contemplates a computer-
readable medium 1022 that includesinstructions 1024 or receives and executesinstructions 1024 responsive to a propagated signal; so that a device connected to anetwork 235 may communicate voice, video, audio, images or any other data over thenetwork 235. Theinstructions 1024 may be implemented with hardware, software and/or firmware, or any combination thereof. Further, theinstructions 1024 may be transmitted or received over thenetwork 235 via acommunication interface 1018. Thecommunication interface 1018 may be a part of theprocessor 1002 or may be a separate component. Thecommunication interface 1018 may be created in software or may be a physical connection in hardware. Thecommunication interface 1018 may be configured to connect with anetwork 235, external media, thedisplay 1014, or any other components insystem 1000, or combinations thereof. The connection with thenetwork 235 may be a physical connection, such as a wired Ethernet connection or may be established wirelessly as discussed below. Likewise, the additional connections with other components of thesystem 1000 may be physical connections or may be established wirelessly. In the case of aservice provider server 240, athird party server 250, anadvertising services server 260, the servers may communicate with users 120AA-NN and therevenue generators 110A-N through thecommunication interface 1018. - The
network 235 may include wired networks, wireless networks, or combinations thereof. The wireless network may be a cellular telephone network, an 802.11, 802.16, 802.20, or WiMax network. Further, thenetwork 235 may be a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to TCP/IP based networking protocols. - The computer-
readable medium 1022 may be a single medium, or the computer-readable medium 1022 may be a single medium or multiple media, such as a centralized or distributed database, and/or associated caches and servers that store one or more sets of instructions. The term “computer-readable medium” may also include any medium that may be capable of storing, encoding or carrying a set of instructions for execution by a processor or that may cause a computer system to perform any one or more of the methods or operations disclosed herein. - The computer-
readable medium 1022 may include a solid-state memory such as a memory card or other package that houses one or more non-volatile read-only memories. The computer-readable medium 1022 also may be a random access memory or other volatile re-writable memory. Additionally, the computer-readable medium 1022 may include a magneto-optical or optical medium, such as a disk or tapes or other storage device to capture carrier wave signals such as a signal communicated over a transmission medium. A digital file attachment to an e-mail or other self-contained information archive or set of archives may be considered a distribution medium that may be a tangible storage medium. Accordingly, the disclosure may be considered to include any one or more of a computer-readable medium or a distribution medium and other equivalents and successor media, in which data or instructions may be stored. - Alternatively or in addition, dedicated hardware implementations, such as application specific integrated circuits, programmable logic arrays and other hardware devices, may be constructed to implement one or more of the methods described herein. Applications that may include the apparatus and systems of various embodiments may broadly include a variety of electronic and computer systems. One or more embodiments described herein may implement functions using two or more specific interconnected hardware modules or devices with related control and data signals that may be communicated between and through the modules, or as portions of an application-specific integrated circuit. Accordingly, the present system may encompass software, firmware, and hardware implementations.
- The methods described herein may be implemented by software programs executable by a computer system. Further, implementations may include distributed processing, component/object distributed processing, and parallel processing. Alternatively or in addition, virtual computer system processing maybe constructed to implement one or more of the methods or functionality as described herein.
- Although components and functions are described that may be implemented in particular embodiments with reference to particular standards and protocols, the components and functions are not limited to such standards and protocols. For example, standards for Internet and other packet switched network transmission (e.g., TCP/IP, UDP/IP, HTML, HTTP) represent examples of the state of the art. Such standards are periodically superseded by faster or more efficient equivalents having essentially the same functions. Accordingly, replacement standards and protocols having the same or similar functions as those disclosed herein are considered equivalents thereof.
- The illustrations described herein are intended to provide a general understanding of the structure of various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus, processors, and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. Additionally, the illustrations are merely representational and may not be drawn to scale. Certain proportions within the illustrations may be exaggerated, while other proportions may be minimized. Accordingly, the disclosure and the figures are to be regarded as illustrative rather than restrictive.
- Although specific embodiments have been illustrated and described herein, it should be appreciated that any subsequent arrangement designed to achieve the same or similar purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all subsequent adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, may be apparent to those of skill in the art upon reviewing the description.
- The Abstract is provided with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, various features may be grouped together or described in a single embodiment for the purpose of streamlining the disclosure. This disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter may be directed to less than all of the features of any of the disclosed embodiments. Thus, the following claims are incorporated into the Detailed Description, with each claim standing on its own as defining separately claimed subject matter.
- The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments, which fall within the true spirit and scope of the description. Thus, to the maximum extent allowed by law, the scope is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
Claims (25)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/239,982 US20100082629A1 (en) | 2008-09-29 | 2008-09-29 | System for associating data items with context |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/239,982 US20100082629A1 (en) | 2008-09-29 | 2008-09-29 | System for associating data items with context |
Publications (1)
Publication Number | Publication Date |
---|---|
US20100082629A1 true US20100082629A1 (en) | 2010-04-01 |
Family
ID=42058617
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/239,982 Abandoned US20100082629A1 (en) | 2008-09-29 | 2008-09-29 | System for associating data items with context |
Country Status (1)
Country | Link |
---|---|
US (1) | US20100082629A1 (en) |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100169323A1 (en) * | 2008-12-29 | 2010-07-01 | Microsoft Corporation | Query-Dependent Ranking Using K-Nearest Neighbor |
US20100257165A1 (en) * | 2009-04-03 | 2010-10-07 | Verizon Patent And Licensing Inc. | Apparatuses, methods and systems for improving the relevancy of ipg search results on a wireless user's handset and television |
US20110320441A1 (en) * | 2010-06-25 | 2011-12-29 | Microsoft Corporation | Adjusting search results based on user social profiles |
WO2012022021A1 (en) | 2010-08-16 | 2012-02-23 | Nokia Corporation | Method and apparatus for executing device actions based on context awareness |
US20120054178A1 (en) * | 2010-08-27 | 2012-03-01 | Samsung Electronics Co., Ltd. | Context-aware media interaction |
US20130044912A1 (en) * | 2011-08-19 | 2013-02-21 | Qualcomm Incorporated | Use of association of an object detected in an image to obtain information to display to a user |
WO2013090723A1 (en) * | 2011-12-16 | 2013-06-20 | Facebook, Inc. | Advertisement based on application-created social content |
EP2669858A1 (en) * | 2012-05-31 | 2013-12-04 | Apple Inc. | Automatically updating a display of text based on context |
WO2015164719A1 (en) * | 2014-04-25 | 2015-10-29 | West Publishing | Systems and methods for generating location based entitlements |
US20160050167A1 (en) * | 2014-08-18 | 2016-02-18 | Google Inc. | Matching conversions from applications to selected content items |
US20170352055A1 (en) * | 2016-06-01 | 2017-12-07 | Facebook, Inc. | Real-time tracking of offline transactions |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6236768B1 (en) * | 1997-10-14 | 2001-05-22 | Massachusetts Institute Of Technology | Method and apparatus for automated, context-dependent retrieval of information |
US20030200192A1 (en) * | 2002-04-18 | 2003-10-23 | Bell Brian L. | Method of organizing information into topical, temporal, and location associations for organizing, selecting, and distributing information |
US20080005071A1 (en) * | 2006-06-28 | 2008-01-03 | Microsoft Corporation | Search guided by location and context |
US7346606B2 (en) * | 2003-06-30 | 2008-03-18 | Google, Inc. | Rendering advertisements with documents having one or more topics using user topic interest |
US20080133495A1 (en) * | 2006-11-30 | 2008-06-05 | Donald Fischer | Search results weighted by real-time sharing activity |
US20080147633A1 (en) * | 2006-12-15 | 2008-06-19 | Microsoft Corporation | Bringing users specific relevance to data searches |
US20080214149A1 (en) * | 2005-09-14 | 2008-09-04 | Jorey Ramer | Using wireless carrier data to influence mobile search results |
US20080281794A1 (en) * | 2007-03-06 | 2008-11-13 | Mathur Anup K | "Web 2.0 information search and presentation" with "consumer == author" and "dynamic Information relevance" models delivered to "mobile and web consumers". |
US7539676B2 (en) * | 2006-04-20 | 2009-05-26 | Veveo, Inc. | User interface methods and systems for selecting and presenting content based on relationships between the user and other members of an organization |
US7577665B2 (en) * | 2005-09-14 | 2009-08-18 | Jumptap, Inc. | User characteristic influenced search results |
US7734624B2 (en) * | 2002-09-24 | 2010-06-08 | Google, Inc. | Serving advertisements based on content |
US7849082B2 (en) * | 2006-11-17 | 2010-12-07 | W.W. Grainger, Inc. | System and method for influencing display of web site content |
-
2008
- 2008-09-29 US US12/239,982 patent/US20100082629A1/en not_active Abandoned
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6236768B1 (en) * | 1997-10-14 | 2001-05-22 | Massachusetts Institute Of Technology | Method and apparatus for automated, context-dependent retrieval of information |
US20030200192A1 (en) * | 2002-04-18 | 2003-10-23 | Bell Brian L. | Method of organizing information into topical, temporal, and location associations for organizing, selecting, and distributing information |
US7734624B2 (en) * | 2002-09-24 | 2010-06-08 | Google, Inc. | Serving advertisements based on content |
US7346606B2 (en) * | 2003-06-30 | 2008-03-18 | Google, Inc. | Rendering advertisements with documents having one or more topics using user topic interest |
US20080214149A1 (en) * | 2005-09-14 | 2008-09-04 | Jorey Ramer | Using wireless carrier data to influence mobile search results |
US7577665B2 (en) * | 2005-09-14 | 2009-08-18 | Jumptap, Inc. | User characteristic influenced search results |
US7539676B2 (en) * | 2006-04-20 | 2009-05-26 | Veveo, Inc. | User interface methods and systems for selecting and presenting content based on relationships between the user and other members of an organization |
US20080005071A1 (en) * | 2006-06-28 | 2008-01-03 | Microsoft Corporation | Search guided by location and context |
US7849082B2 (en) * | 2006-11-17 | 2010-12-07 | W.W. Grainger, Inc. | System and method for influencing display of web site content |
US20080133495A1 (en) * | 2006-11-30 | 2008-06-05 | Donald Fischer | Search results weighted by real-time sharing activity |
US20080147633A1 (en) * | 2006-12-15 | 2008-06-19 | Microsoft Corporation | Bringing users specific relevance to data searches |
US20080281794A1 (en) * | 2007-03-06 | 2008-11-13 | Mathur Anup K | "Web 2.0 information search and presentation" with "consumer == author" and "dynamic Information relevance" models delivered to "mobile and web consumers". |
Cited By (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100169323A1 (en) * | 2008-12-29 | 2010-07-01 | Microsoft Corporation | Query-Dependent Ranking Using K-Nearest Neighbor |
US20100257165A1 (en) * | 2009-04-03 | 2010-10-07 | Verizon Patent And Licensing Inc. | Apparatuses, methods and systems for improving the relevancy of ipg search results on a wireless user's handset and television |
US9110990B2 (en) * | 2009-04-03 | 2015-08-18 | Verizon Patent And Licensing Inc. | Apparatuses, methods and systems for improving the relevancy of interactive program guide search results on a wireless user's handset and television |
US20110320441A1 (en) * | 2010-06-25 | 2011-12-29 | Microsoft Corporation | Adjusting search results based on user social profiles |
EP2606437A4 (en) * | 2010-08-16 | 2015-04-01 | Nokia Corp | METHOD AND APPARATUS FOR PERFORMING ACTIONS OF DEVICES BASED ON CONTEXT KNOWLEDGE |
WO2012022021A1 (en) | 2010-08-16 | 2012-02-23 | Nokia Corporation | Method and apparatus for executing device actions based on context awareness |
EP2606437A1 (en) * | 2010-08-16 | 2013-06-26 | Nokia Corp. | Method and apparatus for executing device actions based on context awareness |
CN103221948A (en) * | 2010-08-16 | 2013-07-24 | 诺基亚公司 | Method and apparatus for executing device actions based on context awareness |
US20120054178A1 (en) * | 2010-08-27 | 2012-03-01 | Samsung Electronics Co., Ltd. | Context-aware media interaction |
US20130044912A1 (en) * | 2011-08-19 | 2013-02-21 | Qualcomm Incorporated | Use of association of an object detected in an image to obtain information to display to a user |
US9245193B2 (en) | 2011-08-19 | 2016-01-26 | Qualcomm Incorporated | Dynamic selection of surfaces in real world for projection of information thereon |
WO2013090723A1 (en) * | 2011-12-16 | 2013-06-20 | Facebook, Inc. | Advertisement based on application-created social content |
US9105052B2 (en) | 2011-12-16 | 2015-08-11 | Facebook, Inc. | Advertisement based on application-created social content |
US8788340B2 (en) | 2011-12-16 | 2014-07-22 | Facebook, Inc. | Advertisement based on application-created social content |
US9530120B2 (en) | 2012-05-31 | 2016-12-27 | Apple Inc. | Automatically updating a display of text based on context |
JP2013250972A (en) * | 2012-05-31 | 2013-12-12 | Apple Inc | Automatically updating display of text based on context |
EP2669858A1 (en) * | 2012-05-31 | 2013-12-04 | Apple Inc. | Automatically updating a display of text based on context |
WO2015164719A1 (en) * | 2014-04-25 | 2015-10-29 | West Publishing | Systems and methods for generating location based entitlements |
US9596600B2 (en) | 2014-04-25 | 2017-03-14 | Thomson Reuters Global Resources Uc | Systems and methods for generating location based entitlements |
US20160050167A1 (en) * | 2014-08-18 | 2016-02-18 | Google Inc. | Matching conversions from applications to selected content items |
US10373192B2 (en) * | 2014-08-18 | 2019-08-06 | Google Llc | Matching conversions from applications to selected content items |
US10891650B2 (en) | 2014-08-18 | 2021-01-12 | Google Llc | Matching conversions from applications to selected content items |
US20170352055A1 (en) * | 2016-06-01 | 2017-12-07 | Facebook, Inc. | Real-time tracking of offline transactions |
US10796338B2 (en) * | 2016-06-01 | 2020-10-06 | Facebook, Inc. | Real-time tracking of offline transactions |
US20200394681A1 (en) * | 2016-06-01 | 2020-12-17 | Facebook, Inc. | Real-time tracking of offline transactions |
US11631108B2 (en) * | 2016-06-01 | 2023-04-18 | Meta Platforms, Inc. | Real-time tracking of offline transactions |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20100082398A1 (en) | System for providing contextually relevant data | |
US8635106B2 (en) | System for targeting data to users on mobile devices | |
US20100082629A1 (en) | System for associating data items with context | |
US8423003B2 (en) | System for serving targeted advertisements over mobile messaging services | |
US8386310B2 (en) | System for measuring web traffic related to an offline advertising campaign | |
US20100312646A1 (en) | System for serving advertisements targeted to geographic areas over mobile devices | |
US7921107B2 (en) | System for generating query suggestions using a network of users and advertisers | |
US9881301B2 (en) | Conversion tracking of a user across multiple devices | |
US10748186B2 (en) | Providing a modified content item to a user | |
US20090247140A1 (en) | System for providing mobile advertisement actions | |
US20090199229A1 (en) | System for providing advertisements across multiple channels | |
US10953324B1 (en) | Using game data for providing content items | |
US20090164299A1 (en) | System for providing a user interface for displaying and creating advertiser defined groups of mobile advertisement campaign information targeted to mobile carriers | |
US20150310483A1 (en) | Determining application conversions | |
US20090248486A1 (en) | System for suggesting categories of mobile keywords to revenue generators | |
US20100022222A1 (en) | System for providing search services over mobile messaging | |
US20100023495A1 (en) | System for suggesting keywords based on mobile specific attributes | |
US20140304063A1 (en) | Determining resource allocation for content distrubution | |
US20090247139A1 (en) | System for adapting online advertising campaigns to incorporate mobile advertising | |
US20090247192A1 (en) | System for mobile advanced matching |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: YAHOO| INC.,CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DAVIS, MARC;YI, JEONGHEE;SIGNING DATES FROM 20080925 TO 20080926;REEL/FRAME:021614/0364 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: YAHOO HOLDINGS, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:YAHOO| INC.;REEL/FRAME:042963/0211 Effective date: 20170613 |
|
AS | Assignment |
Owner name: OATH INC., NEW YORK Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:YAHOO HOLDINGS, INC.;REEL/FRAME:045240/0310 Effective date: 20171231 |