US20090125517A1 - Method and system for keyword correlation in a mobile environment - Google Patents

Method and system for keyword correlation in a mobile environment Download PDF

Info

Publication number
US20090125517A1
US20090125517A1 US12/268,914 US26891408A US2009125517A1 US 20090125517 A1 US20090125517 A1 US 20090125517A1 US 26891408 A US26891408 A US 26891408A US 2009125517 A1 US2009125517 A1 US 2009125517A1
Authority
US
United States
Prior art keywords
user
message
mobile client
keywords
messages
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
Application number
US12/268,914
Inventor
Dilip Krishnaswamy
Nakul Verma
Vladimir Bychkovsky
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Qualcomm Inc
Original Assignee
Qualcomm Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Qualcomm Inc filed Critical Qualcomm Inc
Priority to US12/268,914 priority Critical patent/US20090125517A1/en
Priority to CN200880123867.9A priority patent/CN101911619B/en
Priority to PCT/US2008/083657 priority patent/WO2009065052A1/en
Priority to KR1020107013070A priority patent/KR101195630B1/en
Priority to CN200880123906.5A priority patent/CN102119513B/en
Priority to CN201710372528.5A priority patent/CN107196851A/en
Priority to CN200880123706.XA priority patent/CN101911618B/en
Priority to EP08849499A priority patent/EP2225858A1/en
Priority to PCT/US2008/083680 priority patent/WO2009065071A1/en
Priority to PCT/US2008/083650 priority patent/WO2009065045A1/en
Priority to CN2008801239309A priority patent/CN102017550A/en
Priority to JP2010534247A priority patent/JP5209733B2/en
Priority to EP08848766A priority patent/EP2232798A1/en
Priority to JP2010534243A priority patent/JP5134091B2/en
Priority to EP08850179A priority patent/EP2225860A1/en
Priority to CN200880123907.XA priority patent/CN101911620B/en
Priority to JP2010534234A priority patent/JP5762746B2/en
Priority to PCT/US2008/083672 priority patent/WO2009065064A1/en
Priority to KR1020107013073A priority patent/KR101161078B1/en
Priority to EP08851034A priority patent/EP2225861A1/en
Priority to PCT/US2008/083676 priority patent/WO2009065067A1/en
Priority to KR1020107013114A priority patent/KR101172968B1/en
Priority to EP08849548A priority patent/EP2225859A1/en
Priority to EP08850889A priority patent/EP2223479A1/en
Priority to JP2010534240A priority patent/JP5345631B2/en
Priority to CN200880123555.8A priority patent/CN101911617B/en
Priority to KR1020107013116A priority patent/KR101195640B1/en
Priority to KR1020107013111A priority patent/KR101134248B1/en
Priority to PCT/US2008/083667 priority patent/WO2009065060A1/en
Priority to JP2010534237A priority patent/JP2011507055A/en
Priority to KR1020107013102A priority patent/KR101190446B1/en
Priority to JP2010534245A priority patent/JP5307153B2/en
Assigned to QUALCOMM INCORPORATED reassignment QUALCOMM INCORPORATED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BYCHKOVSKY, VLADIMIR, KRISHNASWAMY, DILIP, VERMA, NAKUL
Publication of US20090125517A1 publication Critical patent/US20090125517A1/en
Priority to JP2013000190A priority patent/JP5657712B2/en
Priority to JP2014096346A priority patent/JP2014194796A/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/004Artificial life, i.e. computing arrangements simulating life
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • H04L12/1859Arrangements for providing special services to substations for broadcast or conference, e.g. multicast adapted to provide push services, e.g. data channels
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/21Monitoring or handling of messages
    • H04L51/212Monitoring or handling of messages using filtering or selective blocking
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/58Message adaptation for wireless communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/04Protocols specially adapted for terminals or networks with limited capabilities; specially adapted for terminal portability
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/2866Architectures; Arrangements
    • H04L67/30Profiles
    • H04L67/306User profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/52Network services specially adapted for the location of the user terminal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/53Network services using third party service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/535Tracking the activity of the user
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/61Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources taking into account QoS or priority requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/08Protocols for interworking; Protocol conversion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/487Arrangements for providing information services, e.g. recorded voice services or time announcements
    • H04M3/4872Non-interactive information services
    • H04M3/4878Advertisement messages
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/12Messaging; Mailboxes; Announcements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/20Services signaling; Auxiliary data signalling, i.e. transmitting data via a non-traffic channel
    • H04W4/21Services signaling; Auxiliary data signalling, i.e. transmitting data via a non-traffic channel for social networking applications
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management
    • H04W8/18Processing of user or subscriber data, e.g. subscribed services, user preferences or user profiles; Transfer of user or subscriber data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • H04L12/189Arrangements for providing special services to substations for broadcast or conference, e.g. multicast in combination with wireless systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/07User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail characterised by the inclusion of specific contents
    • H04L51/18Commands or executable codes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/21Monitoring or handling of messages
    • H04L51/214Monitoring or handling of messages using selective forwarding

Definitions

  • This disclosure relates to wireless communications.
  • the present disclosure relates to wireless communications systems usable for targeted-content-message processing and related transactions.
  • Mobile Targeted-Content-Message (TCM)-enabled systems can be described as systems capable of delivering targeted content information, such as local weather reports and advertisements targeted to a particular demographic, to wireless communication devices (WCDs), such as cellular telephones or other forms of wireless access terminals (W-ATs). Such systems may also provide a better user experience by presenting non-intrusive targeted-content-messages that are likely to be of interest to a user.
  • targeted content information such as local weather reports and advertisements targeted to a particular demographic
  • WCDs wireless communication devices
  • W-ATs wireless access terminals
  • a mobile TCM-enabled system is a M-TCM-PS capable of delivering advertisements to wireless communication devices (WCDs).
  • WCDs wireless communication devices
  • a M-TCM-PS can provide such things as an advertisement sales conduit for a cellular provider to provide advertisements on a W-AT, as well as some form of analytical interface to report back on the performance of various advertisement campaigns.
  • a particular consumer benefit of mobile advertising is that it can provide alternate/additional revenue models for wireless services so as to allow more economical access to the wireless services to those consumers willing to accept advertisements. For example, the revenue generated through advertising may allow W-AT users to enjoy various services without paying the full subscription price usually associated with such services.
  • TCMs In order to increase the effectiveness of TCMs on W-ATs, it can be beneficial to provide targeted information, i.e., TCMs which are deemed likely to be well received by, and/or of likely interest to, a particular person or a designated group of people.
  • Targeted-Content-Message (TCM) information can be based on immediate needs or circumstances, such as a need to find emergency roadside service or the need for information about a travel route.
  • Targeted-Content-Message information can also be based on specific products or services (e.g., games) for which a user has demonstrated past interest, and/or based on demographics, for example, a determination of an age and income group likely to be interested in a particular product.
  • Targeted Advertisements are an example of TCMs.
  • Targeted advertisements can provide a number of advantages (over general advertisements) including: (1) in an economic structure based on cost per view, an advertiser may be able to increase the value of his advertising budget by limiting paid advertising to a smaller set of prospects; and (2) as targeted advertisements are likely to represent areas of interest for a particular user, the likelihood that users will respond positively to targeted advertisements increases substantially.
  • GLBA Graham-Leach-Bliley Act
  • 222 “Privacy of Customer Information.”
  • Common carriers also may be restricted from using personal information about their subscribers for marketing purposes.
  • the GLBA prohibits access to individually identifiable customer information, as well as the disclosure of location information, without the express prior authorization of the customer.
  • a method for determining a suitability for a mobile client to display information includes receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, monitoring user interaction of the respective first messages on the mobile client, determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, receiving a set of target keywords associated with a target message, performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and displaying the target message on the mobile client dependent upon the matching parameters.
  • a mobile client configured to display information, includes a receiving circuit configured to receive a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message, a monitoring agent configured to monitor user interaction of the respective first messages on the mobile client, a determining agent configured to determine a user selection rate for each unique first keyword of the plurality of sets of first keywords, a filtering agent configured to perform one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and a display configured to display the target message on the mobile client dependent upon the matching parameters.
  • a mobile client configured to display information includes a receiving circuit configured to receive a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message, a monitoring means for monitoring user interaction of the respective first messages on the mobile client, a determining means for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, a filtering means for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and a display configured to display the target message on the mobile client dependent upon the matching parameters.
  • an apparatus for determining a suitability for a mobile client to display information includes one or more processors located on the mobile client, and one or more electronic memories each readable by at least one processor, the electronic memories containing instructions for: receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, monitoring user interaction of the respective first messages on the mobile client, determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, receiving a set of target keywords associated with a target message, performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and displaying the target message on the mobile client dependent upon the matching parameters.
  • a computer program product includes a computer-readable medium that in turn includes instructions for receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, instructions for monitoring user interaction of the respective first messages on the mobile client, instructions for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, instructions for receiving a set of target keywords associated with a target message, instructions for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and instructions for displaying the target message on the mobile client dependent upon the matching parameters.
  • FIG. 1 is a diagram showing the interaction between an exemplary wireless access terminal (W-AT) and an advertising infrastructure.
  • An advertising infrastructure is an example of a targeted-content-message-processing infrastructure.
  • FIG. 2 is schematic block diagram showing the operation of an exemplary W-AT having an on-board user profile generation agent.
  • FIG. 3 is a schematic block diagram showing an exemplary operation of a data transfer of a user profile generation agent.
  • FIG. 4 is a schematic block diagram handling an exemplary request for profile data processing.
  • FIG. 5 is a schematic block diagram showing an exemplary operation of a user profile generation agent.
  • FIG. 6 is a flowchart outlining an exemplary operation for generating and using a user profile.
  • FIG. 7 is a flowchart outlining another exemplary operation for generating and using a user profile.
  • FIG. 8 is a diagram illustrating the use of a one-way hash function for client identity protection when identifiable data is transferred to a mobile advertising/mobile targeted-content-message processing server.
  • FIG. 9 is a diagram illustrating data flow implemented by a proxy server for anonymizing identifiable data transferred to a mobile advertising server/mobile targeted-content-message processing server.
  • FIG. 10 is a diagram illustrating a second data flow implemented by a proxy server for anonymizing identifiable data transferred to a mobile advertising server mobile targeted-content-message processing server.
  • FIG. 11 depicts a communication protocol for advertisement distribution in a mobile targeted content message-enabled network.
  • FIG. 12 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 13 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 14 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 15 depicts a timeline for a first communication protocol for downloading advertising content according to “contact windows” approach.
  • FIG. 16 depicts an alternate timeline for a communication protocol for downloading advertising content according to a defined time schedule.
  • FIG. 17 depicts an alternate timeline for a first communication protocol for downloading content according to a defined time schedule.
  • FIG. 18 is an illustration of a message filtering process.
  • FIG. 19 is an illustration of message filtering process components.
  • FIG. 20 is an illustration of a gating process.
  • FIG. 21 is an illustration of a random sampling logic diagram.
  • FIG. 22 is an illustration of a one-way function based sampling logic diagram.
  • FIG. 23 is an illustration of selection process flow diagram.
  • FIGS. 24A and 24B depict a flowchart of a message selection process.
  • FIG. 25 is a flow chart illustrating an exemplary User Profile Match Indicator (MI) process.
  • MI User Profile Match Indicator
  • FIG. 26 is a block diagram illustrating an exemplary user profile match indicator.
  • FIG. 27 is a flow chart of an exemplary keyword correlation process.
  • FIG. 28 block diagram illustrating an exemplary learning and prediction engine.
  • FIG. 29 block diagram illustrating an exemplary learning and prediction engine in context with other elements of a mobile client.
  • FIG. 30A depicts an exemplary hierarchical keyword organization.
  • FIG. 30B depicts an exemplary non-hierarchical/flattened keyword organization.
  • FIG. 31 depicts a series of graphs representing the expected performance of an exemplary learning process for enabling a mobile client to adapt to user preferences.
  • FIGS. 32A and 32B depict a block diagram illustrating an exemplary process for enabling a mobile client to adapt to user preferences.
  • FIG. 33 is an illustration of a multicast/broadcast message distribution.
  • FIG. 34 is an illustration of an exemplary unicast message distribution protocol.
  • FIG. 35 is an illustration of another exemplary unicast message distribution protocol.
  • FIG. 36 is an illustration of yet another exemplary unicast message distribution protocol.
  • FIG. 37 is an illustration of still another exemplary unicast message distribution protocol.
  • FIGS. 38A-38H depict various captured location data with historical information for a particular user.
  • FIG. 39 and FIG. 40 depict an exemplary set of locations and paths for a user.
  • FIG. 41 is an exemplary Markov Model for the set of locations and paths of FIGS. 39 and 40 .
  • FIG. 42 is diagram of a process flow outlining an exemplary operation for updating the user profile based captured location information.
  • the present disclosure is often depicted as being implemented in (or used with) a cellular telephone.
  • the methods and systems disclosed below may relate to both mobile and non-mobile systems including mobile phones, PDAs and lap-top PCs, as well as any number of specially equipped/modified music players (e.g., a modified Apple iPOD®), video players, multimedia players, televisions (both stationary, portable and/or installed in a vehicle), electronic game systems, digital cameras and video camcorders.
  • TCM Targeted-Content-Message.
  • An advertisement can be an example of a Targeted-Content-Message.
  • M-TCM-PS Mobile Targeted-Content-Message Processing System
  • MAS Mobile advertising system, which may be considered a form of M-TCM-PS.
  • MAEC Mobile advertising enabled client. This can be an example of a Mobile TCM-Enabled Client
  • M-TCM-P Mobile TCM Provider
  • Advertiser A person or an entity that may want to display advertisements through a mobile advertising system (MAS).
  • An advertiser may provide the advertisement data along with respective targeting and playback rules, which may in some instances form advertisement metadata to a MAS.
  • An advertiser is an example of a Mobile TCM Provider.
  • TCM Metadata A term used to identify data that can be used to provide additional information about a respective Targeted-Content-Message (TCM).
  • Advertisement Metadata A term used to identify data that may be used to provide additional information about a respective advertisement. This may include, but is not limited to, mime type, advertisement duration, advertisement viewing start time, advertisement viewing end time, etc. Respective advertisement targeting and playback rules provided by the advertiser may also get attached to an advertisement as metadata for the advertisement. Advertisement Metadata is an example of TCM metadata.
  • Application Developer A person who or an entity that develops an application for the mobile advertising enabled client (MAEC) that can feature advertisements.
  • System Operator A person who or entity that operates a MAS.
  • Third Party Inference Rule Provider A third party (other than a system operator) who may provide user profile inference rules to be used by a User Profile Generation Agent
  • User Profile Generation Agent A functional unit at the client that may receive various pertinent data, such as advertisement inference rules, user behavior from a metric collection agent, location data from a GPS, explicit user preferences entered by a user (if any) and/or user behavior from other client applications, then generate various user profile elements.
  • a User Profile Generation Agent may continuously update a profile based upon information gathered that may be used to characterize user behavior.
  • User Behavior Synthesizer A functional device or agent within a User Profile Generation Agent that may be used to receive a variety of data, such as user behavior information, location information and user profile inference rules to generate synthesized profile attributes.
  • Profile Element Refiner A functional device or agent within a User Profile Generation Agent that may receive profile attributes generated by a user behavior synthesizer as well as a number of user profile inference rules.
  • a Profile Element Refiner may refine profile attributes, process them through queries sent to a profile attribute processor, and generate user profile elements.
  • Profile Attribute Processor A server and/or resident agent of a server that may process profile attribute requests that may require data-intensive lookups, and then respond with refined profile attributes.
  • TCM Filtering Agent A client agent that may receive a number of TCMs with their respective meta-data, TCM targeting rules and TCM filtering rules, then store some or all of the TCMs in a TCM-cache memory.
  • the filtering agent may also take a user profile as input from the User Profile Generation Agent.
  • Advertisement Filtering Agent A client agent that may receive a number of advertisements with their respective metadata, advertisement targeting rules and advertisement filter rules, then store some or all of the received advertisements in an advertisement cache memory.
  • the filtering agent may also take a user profile as input from the User Profile Generation Agent.
  • An advertising filtering agent is an example of a TCM filtering agent.
  • TCM Cache Manager A client agent that can maintain a targeted content-message cache.
  • a cache manager may take cached targeted content-messages from a filtering agent, and respond to content-message requests from other applications on the access terminal.
  • the term ‘cache’ can refer to a very broad set of memory configurations, include a single storage device, a set of distributed storage devices (local and/or not local) and so on. Generally, it should be appreciated that the term ‘cache’ can refer to any memory usable to speed up information display, processing or data transfer.
  • Advertisement Cache Manager A client agent that can maintain an advertisement cache.
  • a cache manager may take cached advertisements from a filtering agent and respond to advertisement requests from other applications on the access terminal.
  • An advertisement cache manager is an example of a TCM cache manager.
  • User Profile Attributes User behavior, interests, demographic information, and so on that may be synthesized by a user behavior synthesizer to form profile attributes, which may be viewed as intermediate pre-synthesized forms of data that may be further processed and refined by a profile element refiner into more refined user profile elements.
  • User Profile Elements Items of information used to maintain a user profile, which may include various types of data useful to categorize or define the user's interests, behavior, demographic, etc.
  • TCM Targeting Rules may include rules related to the presentation of a targeted-content-message specified by a Mobile TCM Provider.
  • Advertisement Targeting Rules may include rules specified by advertisers to impose rules/restrictions on how advertisements may be displayed and/or rules to target an advertisement towards a particular segment of users. They may be specific to a number of criteria, such as an advertisement campaign or advertisement group. Advertisement Targeting Rules are an example of TCM Targeting Rules.
  • TCM Playback Rules These can include display rules specified by a client application while querying a TCM Cache Manager for TCMs to display in the context of their application.
  • Advertisement Playback Rules These can include display rules specified by a client application while querying an Advertisement Cache Manager for advertisements to display in the context of their application. Advertisement Playback Rules are an example of TCM Playback Rules.
  • TCM Filter Rules These can include rules upon which TCMs may be filtered. Typically, a system operator may specify these rules.
  • Advertisement Filter Rules These can include rules upon which advertisements may be filtered. Typically, a system operator may specify these rules. Advertisement Filter Rules are an example of TCM-Filter-Rules.
  • User Profile Element Inference Rules can include rules, specified by a system operator (and/or a third party), that may be used to determine one or more processes usable to build a user profile from demographic and behavioral data.
  • TCM Telescoping A display or presentation function for a TCM whereby additional presentation material may presented to a user in response to a user request.
  • Advertisement Telescoping An advertisement display or presentation function whereby additional presentation material may be presented to a user in response to a user request. Advertisement Telescoping is an example of TCM telescoping.
  • W-ATs wireless access terminals
  • One of the many approaches of this disclosure used to alleviate privacy issues includes offloading a variety of processes onto a user's W-AT that may, in turn, be used to generate a set of information that likely characterizes the user, i.e., it can create a “user profile” of the user on the W-AT itself. Accordingly, targeted-content-messages, such as advertisements and other media, may be directed to the user's W-AT based on the user's profiles without exposing potentially sensitive customer information to the outside world.
  • M-TCM-PS Mobile TCM Processing System
  • MAS Mobile Advertising System
  • a M-TCM-PS may also provide an analytical interface capable of reporting on the performance of a particular advertisement campaign. Accordingly, an appropriately constructed M-TCM-PS may provide a better consumer experience by presenting only non-intrusive advertisements that are likely to be of interest to consumers.
  • directed content such as commercial advertising
  • content such as stock reports, weather reports, religious information, news and sports information specific to a user's interests, and so on is envisioned within the bounds of this disclosure.
  • directed content may be an advertisement
  • a score for a sports event and a weather report may just as easily be directed content.
  • devices such as advertising servers may be viewed as more general content servers, and advertising-related agents and devices may be more generally thought of as content-related agents and servers. All further discussion is provided in the context of advertisements as an example of a TCM (Targeted Content Message), and it should be noted that such discussion is applicable to Targeted-Content-Messages in general.
  • TCM Targeted-Content-Message
  • FIG. 1 is a diagram of some of the various functional elements of an M-TCM-PS showing the interaction between a TCM-enabled W-AT 100 with a communication network having an advertising infrastructure.
  • the exemplary M-TCM-PS includes the TCM-enabled mobile client/W-AT 100 , a radio-enabled network (RAN) 190 and an advertising infrastructure 150 embedded in the network associated with the wireless WAN infrastructure (not shown in FIG. 1 ).
  • the messaging infrastructure could be available at a remote server not geographically co-located with a cellular base station in the wireless WAN.
  • the W-AT can include a client applications device 110 , a client message delivery interface 112 , a metric collection agent 120 , a message caching manager 122 , a message filtering agent 124 , a metric reporting agent 126 , a message reception agent 120 and a data service layer device 130 .
  • the message delivery infrastructure 150 can include a TCM sales agent 160 , an analytics agent 162 , a message delivery server interface 164 , a message ingestion agent 170 , a message bundling agent 174 , a message distribution agent 176 , a metric database 172 , a metric collection agent 178 , and having a proxy server 182 .
  • the “client side” of the M-TCM-PS can be handled by the W-AT 100 (depicted on the left-hand side of FIG. 1 ).
  • the present W-AT 100 may have TCM-related applications at the applications level 110 , which in turn may be linked to the rest of the M-TCM-PS via a client advertisement interface 112 .
  • the client message delivery interface 112 may provide for metrics/data collection and management. Some of the collected metrics/data may be transferred to the metric reporting agent 126 and/or to the W-AT's data service layer 130 (via the metric collection agent 120 ), without exposing individually identifiable customer information, for further distribution to the rest of the M-TCM-PS.
  • the transferred metrics/data may be provided through the RAN 190 to the message delivery infrastructure 150 (depicted on the right-hand side of FIG. 1 ), which for the present example includes a variety of TCM-related and privacy-protecting servers.
  • the message delivery infrastructure 150 can receive the metrics/data at a data service layer 180 , which in turn may communicate the received metrics/data to a number of metrics/data collection servers (here metric collection agent 178 ) and/or software modules.
  • the metrics/data may be stored in the metric database 172 , and provided to the message delivery server interface 164 where the stored metrics/data may be used for marketing purposes, e.g., advertising, sales and analytics.
  • information of interest may include, among other things, user selections at a W-AT and requests for advertisements executed by the W-AT in response to instructions provided by the message delivery infrastructure 150 .
  • the message delivery server interface 164 can provide a conduit for supplying advertisements (advertising ingestion), bundling advertisements, determining a distribution of advertisements and sending advertising through the data service layer 180 of the message delivery infrastructure 150 to the rest of the M-TCM-PS network.
  • the a message delivery infrastructure 150 can provide the W-AT 100 with the appropriate TCMs, and metadata for the TCMs.
  • the W-AT 100 can be instructed by the message delivery infrastructure 150 to select TCMs based on any available metadata according to rules provided by the message infrastructure 150 .
  • the exemplary W-AT 100 may be enabled to generate, in whole or in part, a user profile for the W-AT's user that, in turn, may be useful to enable the M-TCM-PS to deliver TCMs of likely interest to the user. This may result in better “click-through rates” for various advertisement campaigns and other TCM delivery campaigns.
  • generating a user profile may raise privacy concerns because of the potentially sensitive nature of data that may reside in the user profile.
  • privacy concerns may be alleviated by enabling a user's W-AT to generate a user profile while subsequently limiting the user profile to the confines of the user's W-AT except in very limited (and controlled) circumstances.
  • FIG. 2 is a block diagram showing operational details of the exemplary W-AT of FIG. 1 configured to generate and use a user profile.
  • the exemplary W-AT includes a processing system capable of processing a number of applications including a number of core client applications and a client message delivery interface. Note that some components, such as the message reception agent 128 and data service layer 130 , are omitted from FIG. 2 for simplicity of explanation for the functions relevant to FIG. 2 .
  • a cache memory 240 is shown in communication with the cache manager 122 .
  • External devices e.g., profile attribute processor 270 , system operator (or 3 rd party) 280 and message sales interface 164 , are shown in communication with the client message filtering agent 124 .
  • Devices 270 , 280 and 164 are generally not part of a W-AT, but likely to reside in another portion of a M-TCM-PS network.
  • each of these functional blocks may take a variety of forms including separate pieces of dedicated logic, separate processors running separate pieces of software/firmware, collections of software/firmware residing in a memory and being operated upon by a single processor, and so on.
  • the client applications device 110 may perform any number of functional applications useful for telecommunications (e.g., calls and text messaging) or other tasks (e.g., games) using the platform specific adaptation interface 111 to interface with the client message delivery interface 112 .
  • the client message delivery interface 112 can be used to allow the W-AT 100 to perform a number of useful processes, such as monitor user behavior and pass user-related information to the user profile generation agent 210 .
  • the user profile generation agent 210 may accrue user behavior information from the metrics collection agent 120 , which itself may receive the same or different information from the client message delivery interface 112 .
  • user behavior may include TCM-related responses, such as advertisement clicks and other metrics indicating types and frequency of usage.
  • Other user behavior information may include direct user preferences or authorizations.
  • the metrics collection agent 120 may provide metrics/data to the metrics reporting agent 126 , which in turn may provide the metrics/data information to other components of M-TCM-PS (discussed below) that may be internal or external to a W-AT.
  • the profile attribute processor 270 can process incoming profile attribute processing requests from the W-AT 100 that require (or can otherwise benefit from) data-intensive lookups and respond with refined profile attributes to the user profile generation agent 210 .
  • One function of the user profile generation agent 210 may include providing TCMs that may be provided to the W-AT's user in accordance with relevant filter rules, as well as TCM data and TCM metadata from the sales interface 164 .
  • the filtering agent 220 may also provide filtered messages to the cache manager 122 , which in turn may store and later provide such messages (via cache memory 240 ) for presentation to the user.
  • a user profile generation agent can be any collection of hardware and/or software residing in a Mobile Advertising Enabled W-AT that can be used to collect user behavior information.
  • Potential information sources may include, but are not limited to, applications residing on the user's W-AT, public information available in various accessible databases, previous user responses to advertisements, location data from a resident GPS radio and explicit user preferences entered by the user (if any). Any user profile information gathered may then be processed/synthesized to generate user profile attributes or elements, which may better characterize the user while using less memory resources.
  • user profile inference rules provided by a system operator may drive the particular actions of a W-AT's user profile generation agent.
  • these rules may be of a number of types, including: (1) Basic Rules, which include actions to be performed by a user profile generation agent on a pre-determined schedule associated with each action; and (2) Qualified Rules, which include “action(s)” that are qualified by a “condition”, where the “condition” may define a behavior that needs to be true, and the “action” may define an action taken by a rule engine of the user profile generation agent when the condition is detected to be true.
  • Such rules may be useful in inferring information from specific user actions or behavior.
  • a simple rule for a user profile generation agent might be to store GPS derived location information for the user's W-AT every five minutes.
  • An associated rule could be that the location most frequented within a 09:00-17:00 time range in the day be marked as the user's likely work location.
  • a rule qualified by a condition might be to add a “game” category to the user's list of interests if the user often spends more than 30 minutes a day in the gaming applications on his W-AT.
  • the user profile generation agent may also take as input user preferences including user selection concerning express authorization of the user to derive a profile using location data, other authorizations made by the user and other specific information entered by the user. For example, the user might input his preference to view travel-related advertisements.
  • a user profile generation agent may utilize any retrieved W-AT information to tailor information content in a manner best suited for the W-AT, including the choice of menu layout, such as linear, hierarchical, animated, popup and softkeys.
  • profile generation rules can be interpreted by the W-AT's embedded user profile generation agent, there might be some rules that require large database lookups, e.g., government census data. Since memory on the W-AT may be too limited to accommodate large databases, it may be possible to further refine the already synthesized user behavior and demographic data by offloading the appropriate refinement tasks to a specially configured server at the W-AP side of the M-TCM-PS network.
  • any such external server capable of assisting in user profile generation may be referred to as a “profile attribute processor.” Additional discussion of profile attribute processors is provided below with respect to FIG. 4 .
  • FIG. 3 is a schematic block diagram of the previously presented user profile generation agent 210 shown in the context of interacting with other devices 312 and 280 .
  • Various capabilities of the user profile generation agent 210 are provided in part below.
  • a mobile phone can be carried by a user wherever he/she goes.
  • the W-AT can determine where the user is periodically or a-periodically spending some or most of his/her time.
  • the use of GPS information and demographic data associated with locations that the user frequents may allow the development of at least some portions of a demographic profile associated with the user.
  • Typical demographic profile elements associated with the user's profile using the location information may include, but are not limited to:
  • an M-TCM Enabled Client might be configured by the network to maintain two demographic profiles for the user—one for his “home” location (most frequented location between, say, 21:00-06:00) and one for his “work” location (most frequented location between, say 09:00-17:00).
  • a user profile may be further developed using any of a W-AT's numerous applications. Which applications, e.g., games, a user tends to spend most of his time with or how he interacts with the various applications on the phone may provide an opportunity to build a profile for the user based on his behavior and preferences. Most of the data mining and user behavior profile determination of this sort can be done on the W-AT itself, being driven by user profile inference rules fed to the user profile generation agent 210 .
  • Typical behavioral profile elements associated with a user may include, but are not limited to, the following:
  • profile elements can be inferred from behavior mined by adding hooks to observe application behavior through a native user interface application on a W-AT. It is through such applications that the user may launch other applications. Applications of interest to the user and time spent in these applications can be inferred by monitoring when the user launches and exits a particular application.
  • Rules fed to the user profile generation agent 210 can associate interest categories for a user based on the user's interactions with applications. Interest categories can also be assigned to the user profile using server assisted collaborative filtering on the behavior data collected at the W-AT.
  • Rules that may get downloaded to the user profile generation agent 210 may allow a server to control the functioning of the user profile generation agent 210 in a dynamic fashion.
  • a server By mining raw data on the incumbent W-AT and synthesizing it into more meaningful information (profile attributes), particular sensitive user behavior information can be transformed into advertisement behavior categories and user profile elements versus maintaining data in raw form.
  • An exemplary W-AT can keep track of the messages of interest to the user and the keywords associated with such messages. For example, multiple clicks on the same advertisement may indicate to a user profile agent an interest level associated with the associated keywords and advertisement. On the same lines, games and music of interest to the user can be maintained at the W-AT. Server-assisted mode can also be used to associate user interest categories with the user's profile based on the user's music and game play-lists.
  • such a profile can take a variety of forms, e.g., synthesized profile attributes and elements.
  • some or all data attributes and elements in a user profile may have some confidence level associated with them. That is, because certain elements and attributes are based upon inferences and rules, their results may not be certain and have “fuzziness” associated with them. This fuzziness may be expressed as a confidence level associated with a user profile attribute and element.
  • the profile generator might say that the user is likely to be in the age group from 15-24 with a confidence level of 60%. That means that if 100 users sending more than five-hundred SMS messages per month were to be polled for their age, about 60 of them are likely to fall within the age group of 15-24.
  • the confidence level may indicate the number of times the profile attribute is expected to be accurate in a sample of one-hundred users with the same home location.
  • the exemplary user profile generation agent 210 can also be fed rules to combine confidence levels on the same profile attribute from multiple sources to come up with a unified confidence level for the attribute. For example, if the SMS usage rate indicates that the user is within the age group of 15-24 years with a 60% confidence level and demographic profile for the home location indicates that the user is in age group of 15-24 years with a 20% confidence level, then these two items can be combined with fuzzy logic rules to come up with a unified confidence level for the user lying in the same age group.
  • FIG. 4 is a schematic block diagram for a profile attribute processor 270 handling a request by a W-AT for profile attribute processing.
  • a W-AT may be able to handle most processing, there may be cases where huge database lookups are required to determine portions of a behavior or demographic profile.
  • An example of such cases includes instances where census databases, which may require gigabytes of storage, are useful.
  • a profile attribute processor (or other assisting server) may be used to process user information to provide more refined forms of user profile information.
  • synthesized profile attributes may be gathered at the relevant W-AT, and sent to the profile attribute processor 270 noting that the use of synthesized profile attributes can result in better use of bandwidth.
  • Some of the user profile attributes, which require data-intensive lookups, can be processed by the profile attribute processor 270 optionally by anonymously querying techniques to protect user identities.
  • the profile attribute processor 270 may further refine any received attributes, and provide the refined data to the appropriate W-AT in what may be referred to as a set of refined user profile attributes.
  • the profile attribute processor 270 may process various types of specific and non-specific synthesized data regarding a user's behavior and demographics (e.g., profile attributes) and respond with the appropriate refined profile information.
  • a user's behavior and demographics e.g., profile attributes
  • some form of data scrambling e.g., a hashing function and a number of other tools may be employed via a device, such as the one-way hash function generator 810 of FIG. 8 .
  • a hashing function employed in a W-AT can generate a predictable and unique, but anonymous, value associated with a particular user. Such an approach can enable the W-AT to query external servers without compromising on the privacy of the user.
  • a hashing function may be based on a primary identifier of the W-AT, e.g. a serial number associated with the W-AT, as well as a random value, a pseudo-random value, and a time-based value. Further, the hashing function may be calculated to provide a low probability of collision with other generated values.
  • the W-AT may use the same random number for subsequent queries to allow external servers to associate multiple queries from the same client.
  • the use of the random number can help to prevent external servers (or unauthorized agents) from doing a reverse lookup on a subscriber base to determine a user's identity.
  • the hashed value may be used as an alternate user identifier for the W-AT and provided, along with geographic information or some or items of information from a user profile, and provided to a remote apparatus.
  • one or more targeted content messages can be received from the remote apparatus based on the alternate user identifier and first advertisement-related information to the remote apparatus and/or other information capable of supplementing a user profile. Such information can be incorporated into the user profile of the W-AT.
  • FIG. 9 depicts a particular communication scheme employing a proxy server for securely communicating in a mobile advertising-enabled network.
  • a W-AT 910 (the “M-TCM-Enabled Client”) can send a request (or other message, such as a report or reply) related to a number of services, such as for refinement of user profile information or a request for advertising content, to a wireless application protocol (WAP) proxy 920 .
  • WAP wireless application protocol
  • the WAP proxy 920 can forward the request to a secure proxy server 930 , which may then create a transaction ID, change out the header to remove the W-AT's identification information in favor of the transaction ID, and forward the request to a mobile message delivery server 940 while creating a look-up table containing that information, e.g., the W-AT's IP address, useful to relay a reply.
  • a secure proxy server 930 may then create a transaction ID, change out the header to remove the W-AT's identification information in favor of the transaction ID, and forward the request to a mobile message delivery server 940 while creating a look-up table containing that information, e.g., the W-AT's IP address, useful to relay a reply.
  • the proxy server 930 may use the appropriate transaction ID to forward the mobile message delivery server's reply. Later, the proxy server 930 may delete the look up table entry.
  • the scheme depicted in FIG. 9 can be employed to disallow the mobile message delivery server 940 access to the user's W-AT IP address, which in turn has a number of benefits, such as allowing the delivery of targeted content, e.g., targeted ads, without compromising user identity.
  • targeted content e.g., targeted ads
  • W-ATs may elect not to query the server for refinement of location data in real-time.
  • queries can be sent anonymously and sparsely over an extended period of time (e.g., once a month).
  • a typical schedule could be, for example, to collect location information every 5 minutes for 72 hours.
  • the most frequented location during this time frame or during specific time frames can be used to query the demographic profile of the user from the server at a randomly selected time between 30 and 40 days or by some other schedule specified by a the system operator.
  • FIG. 5 is a schematic block diagram shown depicting an exemplary operation of such a hybrid approach using a user profile generation agent 210 having a user behavior synthesizer 522 and a profile element refiner 524 . While the majority of functionality of the various devices of FIG. 5 has already been discussed above, further functionality will be described below with respect to the following flowcharts.
  • FIG. 6 is a flowchart outlining an exemplary operation for generating and using a user profile.
  • the operation starts in step 602 as a number of user profile inference rules (basic and/or qualified rules) can be received (and subsequently stored) by a W-AT from a system operator or other party.
  • user profile inference rules basic and/or qualified rules
  • basic rules may include pre-scheduled events, e.g., performing a query of the user at a specific time.
  • a respective qualified rule might require the same query to be preceded by a condition and/or event, such as physical status information or operational status information.
  • the received rules can be used to collect raw data, and in step 606 the raw data may be processed/synthesized into user profile elements or attributes noting that while all such processing/synthesizing may occur on board the W-AT, some refinement may occur using external devices, such as the profile attribute processors discussed above. That is, as discussed above raw data and/or synthesized data may be incorporated to form a user profile for the W-AT's user.
  • a rule relating to monitoring SMS messages may be used to change a dynamic property of a user profile when applied to collect raw data and synthesize profile attributes/elements regarding SMS messages.
  • Static data e.g., a user's birth date, may be likewise collected using a rule to query the user, and then applied as an element in a user profile.
  • confidence levels for user profile data can be determined.
  • confidence levels can have a variety of forms, such as a range of numbers, variance statistic, or distribution profile.
  • various received rules plus raw data and synthesized data relating to various user profile elements and attributes, which may form all of a user profile may be used to receive TCMs. That is, as discussed above, in various embodiments a used/usable rule on a W-AT may be used to generate a user profile—along with collected raw data and synthesized data—to provide any number of static or dynamic properties of the user profile, and such information may be used to receive content, such as advertisements, sports scores, weather reports and news directed to subjects of likely interest.
  • rules may be applied to the confidence levels and targeted content messages may be received and displayed based on such confidence information.
  • control of the operation may jump back to step 602 where new/more rules may be received and used to collect data and modify the user's profile.
  • rules may be used based on physical configuration of an W-AT so as to utilize W-AT information to tailor content display in a manner suited for the W-AT to create suitable displays, such as menu layouts having linear, hierarchical, animated, popup and/or softkey attributes.
  • FIG. 7 is a flowchart outlining another exemplary operation for generating and using a user profile.
  • the operation starts in step 702 as a number of user profile inference rules are received by a W-AT from a system operator or other party.
  • the received rules can be used to collect raw data, and in step 706 the raw data may be processed/synthesized into user profile elements or attributes using onboard resources.
  • any item of user profile information may have confidence level information processed and synthesized along with the basic data.
  • a determination may be made as to whether further information or processing is required that may not be practical on a W-AT. For example, assuming that a W-AT has accrued a series of locations for which the W-AT regularly has visited using a GPS, a software agent on the W-AT using one or more rules may determine the need to query a large external database, such as a geographic information service or a national census database on a remote server, to determine a likely ethnicity (or other demographics) of the user. If further information or processing is required, control continues to step 712 ; otherwise, control of the operation may jump to step 720 where profile attributes are used to generate/modify the user's profile.
  • a request may be made of an external device (step 712 ), such as by the profile attribute processor discussed above (optionally using hashing functions and/or proxy servers) to protect user information.
  • the external device can perform any number of refinement steps, such as query large databases, to produce refined user profile attributes.
  • refined user profile attributes may then be provided to the appropriate W-AT, where (in step 720 ) they may be used to generate, modify or otherwise incorporated in a user profile.
  • confidence levels when confidence levels are available for processing, unified confidence levels may be determined based on individual confidence levels. Control of the operation may then jump back to the step 702 where new/more rules may be received and used to collect data and modify the user's profile.
  • FIG. 11 a first communication protocol for TCMs distribution in a M-TCM-enabled network is depicted.
  • This exemplary figure illustrates a possible data flow during a multicast “push” of messages from a message distribution infrastructure.
  • the User Profile Generation Agent in the Mobile Device (W-AT) 100 of FIG. 10 ) can retrieve messages, then select one or more of the received the messages by internal filtering.
  • a network system operator 280 may provide profile attribute processing rules to the profile attribute processor 270 .
  • the profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 and provide an appropriate response through modules on the W-AT 100 .
  • multicast or broadcast advertisements may be received by the W-AT 100 by a multicast/broadcast distribution server 1110 .
  • the W-AT 100 (or other Mobile Device) can be able to receive all messages and determine which messages are to be stored and presented to the user in accordance with the user profile generated at the W-AT 100 and the filter rules also received from the multicast/broadcast distribution server 1110 of FIG. 11 .
  • FIG. 12 depicts a second communication protocol for message distribution in a M-TCM-enabled network.
  • a network system operator 280 may provide profile attribute processing rules to the profile attribute processor 270 , and the profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 to provide an appropriate response through modules on the W-AT 100 .
  • unicast messages may be requested by the W-AT 100 from the unicast message distribution server 1210 .
  • the W-AT 100 may be able to receive all messages over a unicast communication link and determine which messages are to be stored and presented to the user in accordance with the user profile generated at the W-AT 100 and the filter rules also received from the unicast message distribution server 1210 .
  • FIG. 13 depicts another communication protocol for message distribution in a M-TCM-enabled network.
  • a network system operator 280 may provide profile attribute processing rules to the profile attribute processor 270 , and the profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 to provide an appropriate response through modules on the W-AT 100 .
  • the unicast messages distribution server 1310 may receive user profile information provided by the W-AT 100 , process the received user profile information, and then provide the appropriate TCMs to the W-AT 100 .
  • FIG. 14 depicts yet another communication protocol for message distribution in a M-TCM-enabled network. This example may work much the same as the previous examples with respect to the profile attribute processor side of operation. However, message retrieval over the unicast communication link is substantially different.
  • the W-AT 100 may send a request for messages where after the W-AT 100 can receive a set of metadata representative of the various messages available in the message distribution server 1410 .
  • the W-AT 100 may then select a number of messages based on the metadata and on the filtering rules within the W-AT 100 , and provide the selection information to the message distribution server 1410 . Accordingly, the selected messages can then be provided to the W-AT 100 and presented to the user in accordance with the user profile rules.
  • the above approach keeps the user profile local on the W-AT while using optimal network bandwidth when delivering advertisements to the W-AT over the unicast communication link.
  • FIG. 15 depicts a timeline for a first communication protocol for downloading message content according to “contact windows” (see exemplary windows 1510 - 1516 ) approach. This may be used to permit downloading of TCMs at an opportune time without burdening other functions of the W-AT.
  • the W-AT may be able to adjust its sleep mode, if engaged, to the contact windows. In operation, a W-AT can be put into a sleep mode to optimize energy consumption on the platform during content message delivery. It is possible that in a sleep mode, the W-AT may be engaged in other useful operations.
  • a W-AT may be able to be put into a sleep mode while various timing circuitry (not shown) may be programmed or otherwise manipulated to respond to the sleep mode and a contact window or other schedule by disengaging the sleep mode before and/or during the contact window, and possibly re-engaging sleep mode subsequent to receiving TCMs or at the end of the relative contact window.
  • FIG. 16 depicts an alternate timeline for a first communication protocol for downloading targeted-content-message information according to a defined time schedule.
  • this approach may be used to permit downloading of TCMs at an opportune time without burdening other functions of the W-AT.
  • the defined time schedule permits the W-AT to remain in sleep mode except during the defined time schedule.
  • various timing/clock circuitry may be employed to engage and disengage a W-AT to/from sleep mode.
  • the W-AT wakes up to receive TCM information, it can receive targeting meta-data and reception times for future TCMs, which can then be used to determine whether to receive a future TCM based on the user profile and the targeting meta-data, and to schedule an appropriate wakeup time prior to the reception time for a future TCM delivery.
  • FIG. 17 illustrates some of the cache modeling scenarios based on exemplary information streams 1702 , 1722 and 1732 .
  • the cache modeling scenarios are based on various listed classifications.
  • a message cache can be a store house for the messages at a M-TCM-enabled client. Messages may be cached locally to enable immediate play-out of the messages when there is an opportunity to serve a TCM.
  • the actual storage space in a cache may be divided into multiple categories based on different types of classifications. These classifications can be defined by System Operator using filter rules. The amount of space allocated to each category within a classification may be fixed or may be dynamic based on some defined criterion, again defined through a filter rule by the System Operator. Some categories of interest include:
  • Default messages ( 1710 , 1720 and 1730 ): These may be thought of as “fallback” messages that can be marked such by the System Operator. They are shown when no other message satisfying the message type requested by a device application is available for display.
  • Default messages can be candidates for a cache as long as there is at least one message delivery-capable application subscribed with the respective client message delivery engine with the same message type as the candidate default message.
  • default messages may be made to satisfy the minimum gating criteria of device and application capability compliance.
  • a previously stored default message may be replaced by a new one as long as the “normalized” value of the new message is greater than the value of previously stored default messages under the same message type.
  • the maximum number of default messages allowed on a client for each message type may be defined by the system operator through a filtering rule. In various embodiments there may be a fixed number of messages or message memory, or message number and/or memory may be determined dynamically based on a particular message capable application, usage, etc. Typically, in a number of embodiments, the maximum number of default message allowed for each message type is 1.
  • Messages that are marked as default messages primarily serve two purposes: (1) they serve as “fallback” messages in each category and help the system to take advantage of each opportunity to present a message to a user; and (2) they allow a System Operator to offer “tiered pricing” and (optionally) charge more for default messages.
  • Targeted messages ( 1712 , 1722 , 1724 and 1738 ) and non-targeted messages ( 1714 , 1726 and 1740 ):
  • One classification scheme would be to divide a cache store into space for targeted and non-targeted messages.
  • the targeted message cache space can be used to store only messages for which the user profile for the user of the M-TCM-enabled client matches the target user profile contained in the relevant metadata.
  • Impression-based messages ( 1722 ) and action-based messages ( 1724 ) Another classification would be to divide the targeted or non-targeted portion of a cache space based on whether a message is an impression type of TCM delivery campaign or the message is one which solicits a user action to gauge user interest. Partition sizes or ratios for such a sub-classification might be defined by a System Operator or might be dynamically decided by the capabilities and usage rate of message delivery capable applications onboard a respective W-AT.
  • a sub-classification under the targeted message classification could be based on a user interest classification. For example, most of a particular cache space within a targeted message section of a cache could be reserved for the top three user interest categories while any remaining cache resources may be devoted to other categories matching a user's profile. Again the actual ratios or number of interest based categories within such a classification may be defined by a System Operator and/or may be dynamic based on the relative click-through rates for ads (or other messages) within each interest category.
  • FIG. 18 is an illustration of a message filtering process context.
  • One purpose of a message filtering process within a mobile targeted content message delivery system can be to decide which of any available new messages entering the system should be cached at a particular mobile client.
  • a filtering process 1810 may use a number of inputs, such as a user profile of the user maintained within the system, the device and application capabilities on the mobile client, the current cache state on the mobile client and filtering rules defined by a System Operator or some 3 rd party 280 to determine which new messages to cache.
  • a number of selected messages may be determined and stored in cache 1820 along with the respective metadata.
  • FIG. 19 is a data flow diagram for a TCM filtering process within a TCM delivery system in the context of various exemplary functional components.
  • message filtering may be a multi-step process. New messages entering a filtering agent 220 from sales interface 164 may first pass through a gating sub-process 220 - 1 that may determine which received messages are possible candidates for an message cache. Note that the exemplary gating sub-process 220 - 1 may use device and capabilities information from an appropriate storage device 1910 associated with the mobile client, as well as filter rules by the System Operator or some 3 rd party 280 and user profile information from an appropriate agent 210 or storage device.
  • the possible candidates of the gating sub-process 220 - 1 may then be processed by a selection sub-process 220 - 2 that may determine which candidate messages may be replaced in case of message space contention.
  • the selection sub-process 220 - 2 may use filter rules by the System Operator or some 3rd party 280 , user profile information from an appropriate agent 210 or storage device and feedback cache information from a cache manager 122 .
  • FIG. 20 shows an exemplary data flow within the gating process of FIG. 19 .
  • One purpose of this process is to ensure that targeted content messages, such as targeted ads, meet certain requirements before they are forwarded to a selection process.
  • the present process starts in step 2002 where messages and respective metadata may be provided from a sales interface 164 or other device.
  • step 2004 a determination is made as to whether the messages of step 2002 are within the capabilities of the mobile client. That is, messages should be such that they can be supported by the physical plant of a mobile device. For example, if a message is meant only for the secondary device screen but the mobile device at issue does not have one, the message is not suitable. Should the message match device capabilities, control continues to step 2006 ; otherwise, control jumps to step 2020 where the message is rejected for use.
  • step 2008 a determination is made as to whether the messages of step 2002 pass a system operator specified gating criteria match within the applications capabilities of the mobile client. For example, if a message is suitable for adult audiences only, such message would be likely best filtered out for any user that is identified as a minor. Should the message match the specified system operator specified gating criteria, control continues to step 2010 ; otherwise, control jumps to step 2020 where the message is rejected for use.
  • step 2010 a determination is made as to whether the messages of step 2002 pass a sampling criteria match. For example, if a particular advertisement is slated to be provided to only 30% of a demographic, a random number generator (RNG) having a range of 1 to 100 and seeded with its own ESN and a server specified seed may qualify the advertisement if the resultant random number is less than 30%. If the ad/message passes the sampling criteria, control continues to step 2030 where message selection may be performed; otherwise, control jumps to step 2020 where the message is rejected for use.
  • RNG random number generator
  • FIG. 21 is a flowchart depicting a random sampling scheme, which is presented for situations where an operator might want to divide the users into mutually exclusive sets and target different messages to each set. For example, the operator might be under contractual obligation not to show any Pepsi ad and any Coke ad to the same user. Accordingly, the operator might want to target the Pepsi ad to 50% of the subscriber base and Coke ad to the remaining 50% of the subscriber base, making sure that both ads are not shown to the same user.
  • step 2102 a random number generator seed and ESN (electronic serial number) are provided to a mobile client/W-AT.
  • step 2104 a random number generation process is performed to generate a random number between 1 and 100—or between any other range of numbers. Control continues to step 2110 .
  • step 2110 a determination is made as to whether a match is made between the random number of step 2104 and a defined range, e.g., 1 to 50 or 51 to 100 out of a total range of 1 to 100. If a match is made, then control jumps to step 2112 where the message at issue is accepted, or if there are competing ads as with the Coke/Pepsi example above, the first of two messages is accepted; otherwise, control jumps to step 2114 where the message at issue is rejected, or if there are competing ads as with the Coke/Pepsi example above, the first of two ads is rejected while the second ad is accepted.
  • a defined range e.g. 1 to 50 or 51 to 100 out of a total range of 1 to 100.
  • mutually exclusive message targeting within the subscriber base can be done using a one-way function like a hashing scheme on some unique ID, such as a user ID or device ID.
  • a hashing scheme on some unique ID, such as a user ID or device ID.
  • an operator can specify different target user segments based on the result of the hashing calculations. Such a sampling might be done to target a section of users defined by a range of the hash values for their respective ESNs.
  • step 2202 The process starts in step 2202 where unique ID is provided to a mobile client/W-AT.
  • step 2204 a one-way hashing process may be performed to generate a value between any range of numbers. Control continues to step 2210 .
  • step 2210 a determination is made as to whether a match is made between the hashed value of step 2204 and a defined range. If a match is made, then control jumps to step 2212 where the message at issue is accepted, or if there are competing ads as with the Coke/Pepsi example above, the first of two messages is accepted; otherwise, control jumps to step 2214 where the message at issue is rejected, or if there are competing ads as with the Coke/Pepsi example above, the first of two ads is rejected while the second ad is accepted.
  • a client's hash value when a client's hash value does not fall in a sampling range specified by the system operator, the message may be rejected; otherwise, message processing may continue to the next gating criteria or selection phase.
  • an operator might also choose a hybrid approach to sampling users for a particular ad/message distribution campaign by targeting randomly within mutually exclusive sets. As an example, a particular ad campaign might be targeted to a random 20% of the subscriber base that did not get a first ad. This would be achieved by first using a one-way function based sampling to come up with a mutually exclusive set and then to target randomly within the mutually exclusive set.
  • FIG. 23 shows an exemplary data flow within a message selection process 2300 .
  • a purpose of the selection process can be to select messages from a pool of messages that are forwarded to a mobile client/W-AT by a gating process, and store the selected messages in a memory, such as a special client ad/message cache.
  • the selection process 2300 may also be employed to select previously cached-messages that need to be replaced from the cache.
  • a message selector 2310 may receive new messages from a gating device 220 or other instrument performing a gating process, as well as a number of message filter rules from a system operator or 3 rd party 280 . The message selector 2310 may then apply the various filter rules to each new message to determine whether each new message passes some basic criteria, such as whether the new message is age or gender appropriate. Should a particular message not comply with the filter rules, it may be categorized as a rejected new message and discarded.
  • Messages not discarded under the filter rules may be further processed by the message selector 2310 to derive a “target user profile” for each received message to a match indicator calculator 2320 , which may then compare the target user profile(s) to a user profile provided by a user profile generation agent 210 or some other device storing information on a user.
  • the match indicator calculator 2320 may perform a match between each target user profile and the user profile associated with the user or mobile client/W-AT, and provide a match indication “score” to the message selector 2310 that quantizes how well a particular incoming/new message is compatible with the user profile.
  • the match indication “score” ranks well enough, the respective message can be further considered; otherwise, it may become a rejected new message.
  • Messages that are further processed by the message selector 2310 may provide the match indication “score”, along with other message value attributes, such as the message size, duration, memory and display requirements and so on, to a message value calculator 2330 , which in turn can provide a “message value” for such messages back to the message selector 2310 .
  • the message selector 2310 may receive information from a cache manager 122 about the state of an available cache (or portion of a cache devoted to a particular message category), along with cache hit/miss information and the message value for each message in the cache (or relevant portion). Depending on the hit/miss information for a particular message, a message value for a given message may optionally be adjusted.
  • the message selector 2310 may then determine whether a newly received message is to replace one or more existing messages in the cache based on relative message values, and any newly selected messages may then be sent to the cache manager 122 along with the respective message IDs and respective message values, and any replaced messages may be discarded/rejected for further use.
  • FIGS. 24A and 24B depict a flowchart outlining a message selection process for one or more new messages received at a mobile device, such as a W-AT.
  • the exemplary process flowchart shows the high level flow of actions that take place during message selection to determine which new messages to add to a cache and which previously cached message are to be replaced/discarded.
  • step 2400 a determination is made for a first new message whether the size of the message is less than or equal to some maximum message size for a particular cache memory and (optionally) for a particular message category, e.g., movie trailers, baseball highlights, weather reports and clothing sales. If the new message size conforms with the cache memory requirements of step 2400 , control jumps to step 2402 ; otherwise, control continues to step 2408 .
  • some maximum message size for a particular cache memory and (optionally) for a particular message category, e.g., movie trailers, baseball highlights, weather reports and clothing sales.
  • step 2402 the new message is placed in cache memory.
  • step 2404 a message value for the new message is calculated, and a “priority queue” for various messages in the cache—and optionally for a message category of the cache—is updated with the message value of the new message.
  • step 2406 the available cache size is updated (again with an optional updating for the particular message category) based on the new message.
  • message values may be used to maintain a priority queue for each category within the cache. Periodically (on a pre-defined schedule), an engine may recalculate the various message values in the cache and re-adjusts the priority queues based on the new values.
  • step 2430 Such periodic updates to the value based priority queues may result in lesser time being spent when new messages are being considered as cache replacement candidates, since the values in the queue are a good approximation of what the current values would be. The process then continues to step 2430 (discussed below).
  • step 2408 a message value for the new message is calculated.
  • step 2410 a determination is made as to whether the new message is to be a default message. If the new message is to be a default message, control jumps to step 2412 ; otherwise, control continues to step 2420 .
  • step 2412 a determination is made as to whether the value of the new message is greater than the value of a default message of the same type already existing in the cache.
  • New messages marked as default messages and having value greater than one or more of already stored messages can be given priority.
  • the additional size if they are greater in size than the message(s) to be replaced—of if the new message(s) are catering to a new message type for which there are no previous default messages of such category can be calculated since these messages can be accommodated in the cache.
  • Old default messages that are of lower value than the new ones may be marked for replacement.
  • Each message type may typically have a fixed number (typically 1) of default candidates. If the new message value is greater, control jumps to step 2414 ; otherwise, control continues to step 2422 .
  • step 2414 the total size for all default messages is updated, and in step 2424 , existing cached message(s) to be replaced are marked for deletion while the new message is marked for addition to the cache. Note that based on how the cache is divided or allocated to the various categories of messages, new space allocations can be calculated for each category. Control continues to step 2430 .
  • step 2422 the new message is marked for deletion, and control continues to step 2430 .
  • a new message value for each new non-default message may be added to a respective priority queue for various message categories, and control continues to step 2430 .
  • step 2430 a determination is made as to whether there are any more message candidates to be considered. If more message candidates are available, control jumps back to step 2440 where a next message is selected for consideration, and then back up to step 2400 where the next message is made available for processing; otherwise, control continues to step 2450 .
  • step 2454 various messages having the lowest associated value can be marked for deletion for each message category in order to conform with the available memory for each respective category of messages.
  • step 2456 those messages marked for deletion can be removed from the cache, and their respective value entries may also be removed from the respective priority queue.
  • step 2458 those new messages marked for deletion can be requested, and their respective value entries may also be removed from the respective priority queue. Control continues to step 2460 .
  • step 2460 those new messages not marked for deletion can be added to the cache, and their respective value entries may be retained in the respective priority queue. Control continues to step 2470 where the process stops.
  • Calculating a value for a message may consider a number of attributes, based on the type of message. While a number of these attributes may be defined by a server to maintain centralized control over a message delivery scheme, e.g., an advertising campaign, across a message-enabled communication system, some of the attributes that go into message value calculation may be determined on the mobile client/W-AT based on how the respective user interacts with the message.
  • a number of these attributes may be defined by a server to maintain centralized control over a message delivery scheme, e.g., an advertising campaign, across a message-enabled communication system
  • some of the attributes that go into message value calculation may be determined on the mobile client/W-AT based on how the respective user interacts with the message.
  • Revenue indicator (RI) A value in the range of 1 to N (e.g., 100) indicative of the revenue earned per serving/clicking of the message/ad. Higher values indicate higher revenue.
  • Priority indicator A value in the range of 1 to M (e.g., 10) indicative of the priority level the system operator has scheduled for the message based on some measure of performance, e.g., the effectiveness of an advertiser's ad campaign, over a mobile message delivery system. This number may be increased by an operator to increase the priority of a given message delivery campaign.
  • Start and end time of message delivery campaign (T START and T END ): UTC time for the message delivery campaign viewing start time and message campaign viewing end time. After the message campaign viewing end time, the message can expire and may be no longer shown within the mobile message delivery system. It also may be removed from the respective cache at this time.
  • Target message serve count (MAX SERVE ): This is an attribute that defines the maximum number of times the same message can be shown to the same user.
  • Target user actions count (MAX USERACTION ): This is an attribute that defines the maximum number of times a user acts upon a served message after which the message can be expired from the respective cache. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Max message serve count per day (DAILYMAX SERVE ): This is an attribute that defines the maximum number of times the same message can be shown to the same user within a single day.
  • Max user action count per day (DAILYMAX USER — ACTION ): This is an attribute that defines the maximum number of times a user acts upon a served message after which the message is not served to the user for that day. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Cumulative message served count (CUM SERVE ): The number of times an existing message has already been served to a particular user.
  • Cumulative user action count (CUM USER — ACTION ): The number of times an existing message has invoked a user action. Together with the cumulative message served count, the cumulative user action count can be used to calculate a local client click-through rate (LCTR) for the message. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Cumulative message served count per day (DAILYCUM SERVE ): The number of times an existing message has already been served to the user in a given day. This value may be reset to 0 at the beginning of each 24 hour period.
  • Cumulative user action count per day (DAILYCUM USER — ACTION ): The number of times an existing message has invoked a user action in a given day. This value can be reset to 0 at the beginning of each 24 hour period. In various embodiments, this attribute may be applicable only for user-action or click-based ads.
  • MI User Profile match indicator
  • Cache miss state match indicator FLAG CACHE — MISS — MI .
  • applications ask for messages from the cache manager but none of the messages in the cache match the application gating criteria. Such instances can be recorded by the cache manager.
  • This attribute determines whether the new message matches the most recent recorded cache misses. It can be a logical “1” if it matches one of the recent cache misses and a logical “0” otherwise.
  • the flag can be reset once the message is accessed by an application from the cache. If the new message is selected for cache entry, the cache miss entry can be removed from the list of recorded cache misses.
  • PPI Playback Probability Indicator
  • the value calculation can be different for different categories of messages.
  • a separate priority queue can be maintained for each category based on the values calculated using the formula for that particular category.
  • Message Value Calculation Formulae The filter rules from the System Operator may determine the value calculation formula for each category and any weights that go into the calculation.
  • An exemplary generic representation of a formula used to calculate a message value (V) in each category is:
  • MULT_ATTR a is the a th multiplicative value attribute
  • ADD_ATTR b is the b th additive value attribute
  • MAX_ADD_ATTR b is the max value for the b th additive value attribute
  • WT b is the weight assigned to the b th additive attribute in the formula
  • t ELAPSEDi /T INTERVALi
  • f( ⁇ ) is a time-based value decay function
  • T INTERVALi is the i th interval duration during which the message will be shown
  • t ELAPSEDi is the time that has already elapsed in the i th interval
  • MAX SERVEi is the maximum number of times the same message can be shown to the same user within the i th interval
  • CUM SERVEi is the number of times an existing message has already been served to the user within the i th interval.
  • VAL ( PI/ 10*[( RI/ 100 *WT RI )+( MI/ 100 *WT MI )+
  • VAL ( PI/ 10*[( RI/ 100 *WT RI )+(FLAG CACHE — MISS — MI *WT CACHE — MISS — MI )+
  • VAL ( PI/ 10*[( RI/ 100 *WT RI )+( MI/ 100 *WT MI )+(FLAG CACHE — MISS — MI *
  • VAL ( PI/ 10*[( RI/ 100 *WT RI )+(FLAG CACHE — MISS — MI *WT CACHE — MISS — MI )+
  • RI is the revenue indicator value on a scale of 1 to 100
  • PI is the priority indicator value on a scale of 1 to 10
  • CTR is the click-through rate for the message within the system for the given user profile
  • LCTR is the click-through rate for the message for the specific client
  • MI is the match indicator between the target user profile and the user's profile on a scale of 1 to 100
  • FLAG CACHE — MISS — MI is the match indicator between the message type and the cache miss state with a value of either 0 or 1
  • PPI is the message playback probability indicator on a scale of 1 to 100
  • WT RI is the weight for the revenue indicator in the calculation
  • WT MI is the weight for the match indicator in the calculation
  • WT CACHE — MISS — MI is the weight for the cache miss state match flag in the calculation
  • WT CTR is the weight for the user profile specific system click-through rate in the calculation
  • WT LCTR is the weight for the client specific click-through rate for the message in the
  • ⁇ and ⁇ acute over ( ⁇ ) ⁇ are value decay rate constants specified by the system operator based on time
  • the User Profile Match Indicator may be a number, and not necessarily between 0 and 100, which is indicative of how well the target user profile matches the user profile of the user of the Mobile Message Delivery Enabled Client and either his past message/advertisement viewing history or some metric of the his message/advertisement preference(s).
  • MI User Profile Match Indicator
  • the MI can be described as a scalar numerical quantity, it should be appreciated that one or more alternative “weighting” schemes can be devised, for example, using a polynomial function or vectors, according to design preference.
  • other values scalar or non-scalar, single valued or multi-valued, for example
  • a scale quantity between 0 and 100, since this is one of the simplest ranges that can be given. Other ranges may used as desired.
  • One such implementation utilizes fuzzy logic which can be used to generate confidence level values for each of the independent target rule groups specified by the advertiser. From these confidence levels, a weighted summation of these confidence levels can be used to arrive at the match indicator value for the advertisement to the user's profile.
  • fuzzy logic which can be used to generate confidence level values for each of the independent target rule groups specified by the advertiser. From these confidence levels, a weighted summation of these confidence levels can be used to arrive at the match indicator value for the advertisement to the user's profile.
  • fuzzy logic may be used as an example of one type of fuzzy logic
  • the overall match indicator for the message to the user's profile is related to the sum of confidence levels (CONF_LEVEL) times a weight (WT) corresponding to an attribute value (b) divided by the sum of the weight (WT) corresponding to the b th additive attribute.
  • confidence level calculation presume an advertiser who desires to target his advertisement(s) towards females, to females who are in the age range of 15-24 and with an income above 40K, or who are in the age range of 25-34 and with an income greater than 70K. Knowing the values of the user profile elements of interest and presuming the associated confidence levels are:
  • a maximum/minimum approach can be used for the composite rule group of age 15-24 and with income above 40K, or age 25-34 and with income greater than 70K. For example, taking the maximum value of the minimum of the two groupings (e.g., MAX (MIN (40, 65), MIN (35, 45)) results in MAX (40, 35), which is a 40% confidence level for this grouping.
  • MAX MIN (40, 65), MIN (35, 45)
  • the overall MI for the entire rule groups would be the combination of the “female” confidence level 50% and the composite confidence level 40%, factored by the associated WT b and divided by the sum of the associated WT b 's.
  • other forms of fuzzy logic may be used without departing from the spirit and scope of this invention.
  • the confidence levels each attribute for an individual rule group may be represented by an n-dimensional vector.
  • the n-dimensional vector may be a dot-product with other m-dimensional individual groups, if necessary (for example, if the different individual rule groups are separately vectorized), to result in an overall intersection or projection of the advertising rule group confidence.
  • This value can then be scalar manipulated or “dot-product ed” (depending on the projection space) with a mathematical representation of the user's profile, to generate a match indication confidence level.
  • Match algorithms such as a bubble or hierarchal approach may be used.
  • Match algorithms may be resident on the mobile message delivery system or on the mobile message delivery enabled client, if so desired. Additionally, depending on a chosen configuration and resources, portions of these algorithms may be parsed between the message delivery system or the message delivery enabled client.
  • FIG. 25 is a flow chart illustrating an exemplary User Profile Match Indicator (MI) process 2500 according to an embodiment of this invention.
  • the exemplary process 2500 embodies any one or more of the algorithms/schemes discussed above.
  • the exemplary process 2500 is initiated at step 2510 , and continues to step 2520 whereupon message target parameters, e.g., an advertiser's advertisement target parameters, are compiled or characterized.
  • message target parameters e.g., an advertiser's advertisement target parameters
  • step 2530 the exemplary process can proceeds to generating a metric or mathematical representation of the target parameters.
  • this step may simply entail a conversion of the parameter characteristics into a manageable number, such as a scalar value having a range between 0 to 100. Of course, any range, whether positive and/or negative may be used, depending on design preference.
  • Step 2530 can enable an advertisement's target parameters to be represented by a mathematical expression or value. For example, if an advertiser desires to target all females and is not privy to the female-to-male subscriber ratio, then his request would be converted according to the provider's subscriber population breakdown.
  • step 2530 may simply consists of forwarding the parameters to the next step with little or no manipulation. That is, target parameters may already be in a form amenable for processing by the subsequent steps and may not necessitate any conversion. Control continues to step 2540 .
  • an optional conditioning or transformation of the formulated mathematical expression or metric may take place. For example, depending on the complexity of a message's target parameters and the definition space allocated to the message's target parameters, further processing and manipulation may need to be performed. For example, a correlation between different advertisement target parameters may be performed. For instance, if an advertiser desires a female target profile having an age range of between 18-24 years within a particular area code who are new subscribers, confidence levels or other types of mathematical inferences can be made, to provide a simpler or more efficient representation of the entire advertisement target parameter set. It should be appreciated that other forms of correlation or manipulation may be used as deemed appropriate. Additionally, based on the processing capabilities of the mobile client and/or other practical considerations, it may be desired to refine the metric or reduce the complexity of the metric for more effective or more efficient matching. Control continues to step 2540 .
  • a message match algorithm may be performed to determine a match metric or suitability of fit for the message target profile to the user profile. It should be apparent that this process may use any one of several possible matching algorithms described herein or known in the arts. Non-limiting examples are fuzzy logic, statistical methods, neural nets, bubble, hierarchal, and so forth.
  • an overall user match indication value, overall confidence level or other metric of indicating the level of suitability of the message to the user's profile can be generated.
  • the user match profile indication which may, for example, simply be a scalar number or a “yes” or “no” value, control continues to step 2570 where the process is terminated.
  • advertisements and other messages designated for target populations can be matched with a user's profile to determine the suitability of the message/advertisement to the user's profile.
  • the message/advertisement can be forwarded to the user in the expectation that the user will respond favorably to the message, or as per arrangements made with the user. Accordingly, advertisements/messages that are “tailored” to the user can be efficiently disseminated to the user.
  • FIG. 26 is a block diagram illustrating an exemplary user profile match indicator 2600 , according to an embodiment of this invention.
  • the exemplary user profile match indicator 2600 includes a target profile generator 2610 , an advertisement server 2620 , a user profile generator 2630 , a profile-to-profile comparer 2640 , and a storage system 2660 .
  • the comparer 2640 may be housed in a user system (not shown) and can compare information forwarded by the target profile generator 2610 against information forwarded by the user profile generator 2630 .
  • the target profile generator 2610 may forward attributes related to the advertisements provided by the advertising server 2620 , wherein the information/attributes can be compared to the information/attributes of the user's profile, as provided by the user profile generator 2630 .
  • a match indication can be formulated designating the level of suitability or confidence level of the target profile to the user profile.
  • advertisements and/or information from the advertisement server that are consistent with the attributes of the target profile may be forwarded to storage system 2660 .
  • the storage system 2660 may be resident on the user system. Accordingly, “tailored” advertisements and/or information may be forwarded to a user without compromising the privacy of the user's profile.
  • Keyword Correlation based on past viewing history One of the potential inputs in a match indicator calculation described above may be a correlation value derived between the previous messages viewed, i.e. a “viewing history” of the user and new messages. In this context, or messages may be associated with keywords from a dictionary at the advertisement sales interface, according to design preference. With respect to FIG. 27 , a process is described that describes an exemplary generation and use of keyword associated message delivery.
  • keywords can be assigned to various messages.
  • an advertisement directed to women's apparel may have four keywords including “fashion”, “female”, “clothing” and “expensive”.
  • the keyword(s) may be broadly associated with a genre of advertisements/messages or may be individually associated with a particular species of advertisement(s)/message(s). Thus, depending on the level of resolution or discrimination desired, more than one keyword may be associated with a particular advertisement/message or vice versus.
  • keywords may be limited to an advertisement/message dictionary or index.
  • such keywords can be given weights (e.g., a number between 0 and 1) to help describe the strength of association between a particular message and the meaning of the keyword. If keywords are determined to not have an associated or impressed weight, their weights can be assumed to be 1/n where n is the total number of keywords associated with a message. In this manner, a gross averaging weight can be applied by the 1/n factor, in some sense to normalize the overall keyword values to within a desired range.
  • Assigned weights can provide some degree of normalization, especially in the context of multiple keywords (for example, 1/n, given n keywords, with each keyword having a maximum value of 1), or can be used to “value” the keyword or the advertisement/message according a predetermined threshold or estimation. For example, some keywords may have a higher or lower relevance depending on current events or some other factor. Thus, emphasis or de-emphasis can be imposed on these particular keywords via the weighting, as deemed appropriate.
  • Step 2720 is presumed to have the measure of assigning a weight to the keyword as part of the keyword association for a fixed keyword value estimation. However, in some instances a weight may not have been pre-assigned or the weight valuation is undetermined. In those instances, an arbitrary value can be assigned to the keyword, for example, a weight of 1. It is presumed that these keywords are forwarded to a mobile client. Control continues to step 2730 .
  • user response to messages may be monitored.
  • messages can be presented to users whereupon the users may choose to “click” on them or not.
  • click can be assumed to mean any form of user response to the presence of the message or as part of an operational message sequence.
  • a lack of response may be construed as an affirmative non-click or click-away response, analogous in some contexts to a de-selection.
  • a mobile client user's response to various advertisements/messages can be historically gauged.
  • a user's response time for a given advertisement/message or a series of advertisements/messages can also be used to gauge the user's interest therein. For example, a user may click through several advertisements/messages, each having different degrees of relevance or keywords, and the rate of click through or tunneling can be understood to be indicative of user interest. Control continues to step 2740 .
  • a comparison of the user selection (for example, click) of a particular advertisement/message and its corresponding keyword(s) can be performed to establish at least a “baseline” correlation metric.
  • the selection of and/or rate of selection can be used in determining the user's interest in a keyword-associated advertisement/message.
  • a correlation between the various keyword and the user's advertisement/message preference may be provided. This correlation can be accomplished using any one of several methods, such as, for example, statistical methods, fuzzy logic, neural techniques, vector mapping, principal components analysis, and so forth.
  • a correlation metric of the user's response to an advertisement/message can be generated.
  • a “keyword correlation engine” embedded on a message delivery system and/or W-AT may track the total number of times a particular message/advertisement may presented (or forwarded) to a user with a particular keyword (for example, N total-keyword) along with the total number of clicks for that keyword (for example, N_click-keyword).
  • the ratio of N_click-keyword/N total-keyword may be computed to determine the correlation of the keyword to the user's response.
  • the weight for a keyword for a message may be assumed to be 1 if the keyword is specified without an associated weight for a given message.
  • a metric for gauging the reaction or interest of the user to a keyword tagged advertisement can be generated, and refinements or improvements to the match can be devised accordingly.
  • affirmative clicks can be used to indicate a user's interest.
  • a non-click or lack of direct response also may be used to infer an interest level or match relevance.
  • An N-dimensional vector A can be created based on the associated keyword weights.
  • An N-dimensional correlation vector B can be created with the correlation measure of each keyword for the advertisement(s) to the user in each dimension.
  • a scalar correlation measure C to establish the correlation of the advertisement to the user, can then be created which is a function of the vectors A and B.
  • This scalar correlation measure C offers a very simple and direct measure of how well the advertisement is targeted to the specific user based on his previous advertisement viewing history.
  • other methods may be used to correlate the A-to-B correspondence, such as parameterization, non-scalar transformations, and so forth.
  • step 2750 the exemplary embodiments described herein may use any form of matching or keyword-to-user correlation algorithm as deemed necessary. Control continues to step 2750 .
  • the mobile client or user may receive “target keyword(s)” associated with various prospective targeted messages/advertisements.
  • the received target keyword(s) may be evaluated to determine if there is a match or if the keyword(s) meet an acceptable threshold.
  • a matching evaluation can involve higher algorithms, such as statistical methods, fuzzy logic, neural techniques, vector mapping, principal components analysis, and so forth, if so desired.
  • the correlation process of step 2740 and the matching process of step 2760 may be complementary. That is, different algorithms may be used with the respect processes, depending on design preference or depending on the type of advertisement/message keyword forwarded. Control continues to step 2770 .
  • those targeted messages deemed to match within a threshold of acceptance may be forward and/or displayed to the user.
  • the forwarding of the advertisement/message may take any one of several forms, one such form, for example, being simply permitting the matching advertisement/message to be received and viewed by the user's device.
  • a non-match advertisement/message may be forwarded to the user, but is disabled so as to prevent instantiation or viewing.
  • a prior non-acceptable advertisement/message but now acceptable advertisement/message may be resident on the user's device and appropriately viewed.
  • step 2770 the exemplary process 2700 proceeds to step 2780 where the process is terminated.
  • targeted advertising/messages can be filtered to be apropos to the user's interests.
  • the user's interests can be initially established by historically monitoring the user's “click” response on the user's mobile client against a set of advertisements/messages via keyword assignment and matching. Dynamic monitoring can then also be accomplished by updating the user's interest profile, based on currently observed user response(s). Accordingly, a more direct or more efficient dissemination of targeted advertisements/messages can be obtained, resulting in a more satisfying mobile client experience.
  • a significant amount of information can flow through a mobile device associated with a user during the lifetime of the device.
  • the user may interact with some fraction of the information that is presented to it. Due to memory constraints, it may be impossible to store all such information on the mobile device itself. It may not even be feasible to store all the meta-data and the user responses associated with all such information flowing through the device as well.
  • a “keyword learning engine” 2810 capable of capturing user preferences and presented information.
  • a “keyword prediction engine” 2820 based on a learned model, to suggest the likelihood of user interest for new information that is presented to the user. This could help in filtering new content as it arrives on a mobile device, so that relevant information can be presented to the user.
  • meta-data associated with information arriving at a mobile device can be used in the learning and prediction engines 2810 and 2820 . Any user responses associated with presented information can be also used in the learning engine 2820 .
  • the learning engine 2810 may use all past information, e.g., meta-data and the user behavior associated with the respective presented information. Based on the input, the learn engine 2810 can refine such input to provide a learned user preference model. This user preference model may then be used in a prediction engine, which can receive meta-data related to new information, then correlate the meta-data with the user preference model to provide a predicted user match indicator/indication for the new information. This user match indicator/indication can then be used to determine whether or not the information is presented to the user.
  • user preferences can be contextual with respect to the activity that is being learned. For example, a user may have different preferences with regard to advertisements that the user would like to see, and a different set of preferences with regard to web pages that the user would like to browse. For example, a user may read news on the web about crime in the local community news to be aware of such activity from a safety standpoint; however, that should not imply that the user would be interested in purchasing a gun through an advertisement. Therefore a message presentation engine on the platform could reflect different user preferences relative to the web browser preferences of the user. Other contexts could include user preferences related to a music application on the platform or a sports application on the platform. In general, learning and prediction engines may be required for every context.
  • an exemplary architecture and algorithm for learning and prediction for a given context such as processing targeted-content-messages/advertisements.
  • the suggested architecture and algorithms can be applied to different contexts without loss of generality.
  • One task at issue is to learn user preferences from a user's phone usage habits in the given context, such as learning their likes and dislikes from their response to targeted-content-messages (such as an advertisements) that are presented to the user.
  • the goal is to provide a solution with a learning algorithm that is fast and that does not scale with amount of data presented.
  • the available prediction engine may present a match indicator for the information relative to the learned preferences of the given user.
  • This match indicator can be used along with other system constraints (such as revenue or size information optionally) to take a decision on whether to present the information real-time to the user, or to take a decision on whether to store the information on the user's mobile device such as in a space-constrained targeted-content-message cache on the mobile device.
  • a message server 2620 may deliver a single message, such as a Starbucks coffee ad, to a user's mobile device 100 in real-time when the user 2990 is either walking past or driving past a Starbucks store. Based on the prediction model, it may be useful for the mobile device 100 to take a decision on whether to present this message to the user 2990 based on a match indicator value that is generated related to this information.
  • a stream of meta-data information related to various messages may arrive at the mobile device 100 , and a resident prediction algorithm may provide the relative values of match indicators for each message, so that the mobile device 100 may take a decision on which messages to store in a space-constrained cache 240 on the mobile device 100 .
  • a selection function on the mobile device 100 may optionally use additional indictors, such as associated revenue (message value calculation criteria) and size (gating and/or message value calculation criteria), in addition to a match indicator calculation using commands and information from the prediction engine 2820 to take a decision on whether to present a given message to the user 2990 .
  • additional indictors such as associated revenue (message value calculation criteria) and size (gating and/or message value calculation criteria)
  • both the meta-data associated with the user information and the user response may be used by the learning engine 2810 to generate a learned user preference model.
  • individual actions on a per-message basis may or may not be stored in the mobile device 100 . That is, user actions, along with meta-data for a given message may be used to refine the learned user preference model and subsequently the inputs related to the user action and the ad-meta-data are discarded from the system.
  • a keyword dictionary that describes different possible preferences of a user for a given context.
  • the creator of a targeted-content-message may specify those keywords that are relevant to a targeted-content-message in the meta-data for a targeted-content-message.
  • the learning engine 2810 may update the user's preferences related to the keywords based on the response of the user 2990 to the information.
  • the prediction engine 2820 may compute the match indicator for the user that can be used to determine whether or not to present the targeted-content-message to the user 2990 .
  • a keyword dictionary is a flat representation for the purpose of learning.
  • a keyword dictionary that is exposed to the targeted-content-message provider may either be flat or hierarchical in nature.
  • nodes at a higher-level in the keyword tree may represent coarse-grain preference categories such as sports, music, movies or restaurants.
  • Nodes lower in the keyword tree hierarchy may be specify finer-grain preferences of the user such as music sub-categories rock, country-music, pop, rap, etc.
  • the keyword tree may be flattened starting with the bottom of the tree for the purpose of learning.
  • a music node in the tree with four children ⁇ rock, country-music, pop, and rap ⁇ can be flattened to a five node representation with music (general) and the 4 sub-categories.
  • the flattened representation translates to (1+L) leaves for the root of the parent node in the keyword hierarchy.
  • the flattening of the tree can be recursively accomplished starting with the leaves of the tree all the way to the top of the hierarchy such that all intermediate nodes of the tree are connected directly to the root of the tree.
  • a quad-tree representation with k levels would consist of a root node along with 4+4 2 +4 3 + . . . +4 (k ⁇ 1) nodes.
  • FIGS. 30A and 30B depict an exemplary flattening process at an intermediate parent node in the tree for a hierarchical representation.
  • the learning and prediction algorithms may work on a weighted summation metric which effectively results in learning based on a flattened version of a hierarchical tree, if the decision making is done at the top of the tree.
  • keywords each corresponding to a preference one may want to capture with regard to a user.
  • p i corresponds to the user's preference level for the category i.
  • messages are presented sequentially to the learning algorithm.
  • the estimate ⁇ circumflex over (P) ⁇ may start at initial value 0. However, in the presence of available information, one can opt to use a different starting seed. For instance, knowing the local demographics can help to seed the profile of a new mobile user to some average or amalgam. If a seed vector S is available, the initial value of ⁇ circumflex over (P) ⁇ may be set equal to the seed S with no changes to other steps.
  • the learning engine can quickly learn the user preferences from user responses, e.g., the user's “clicking behavior”. That is, the rate of learning can be proportional to the sparseness of the messages and/or user preferences
  • the learning engine is robust to high noise. That is, even if user clicks on a large number of irrelevant messages, as long as she is clicking on a small percentage of relevant messages, a learning engine should be able to learn the underlying preferences.
  • the learning engine can adapt to the new preferences well.
  • the rate of learning for the user selection rates can be determined based on rate of presentation of information, value of an initial seed, and aspects of a user profile.
  • FIG. 31 depicts a modeled learning engine in action with the horizontal axes representing the different keywords (total 500), and the vertical axes represents the strength of an individual's preference—positive implies user like, negative implies dislike.
  • the top graph 3102 shows the underlying user preferences, while the subsequent four graphs 3104 - 3110 show the algorithm's best guess after receiving 50, 100, 500 and 1000 messages respectively.
  • a sparse vector is randomly chosen to represent the underlying preference vector.
  • the user's behavior can be simulated as follows: The user clicks on a truly relevant message about 25% of the time and rest 75% of the time the user clicks on an irrelevant message.
  • the decay parameter D is set to 3000.
  • Information regarding which messages were clicked is passed to a learning engine. It should be noted that for the simulation of the present example, the learning engine is not given any information about whether each message is truly relevant to the user.
  • FIG. 31 it is apparent that a keyword-based user preference representation for individual learning contexts can be desirable and useful on a mobile platform. It should be appreciated that the example of FIG. 31 may be improved by a number of classic adaptive techniques. For example, it may be useful to introduce small degrees of randomness to the prediction model to refine the user's model by further exploring the user's interests in effect performing an “annealing” process characteristic of classic neural network learning.
  • the central learning/adaptive algorithm of Eq. (2) may be modified by varying the decay parameter over time or based on the type of user response (e.g., strong positive, weak positive, neutral, weak negative, strong negative).
  • a strong positive response may contribute positively (A/D(t)) to the estimate ⁇ circumflex over (P) ⁇ (step 6 in the learning engine).
  • the response may contribute negatively ( ⁇ A/D(t)) to the estimate ⁇ circumflex over (P) ⁇ .
  • the response may contribute fractionally ( ⁇ A/D(t)) to the estimate ⁇ circumflex over (P) ⁇ where 0 ⁇ 1.
  • a weak negative response may contribute negatively and fractionally ( ⁇ A/D(t)) to the estimate ⁇ circumflex over (P) ⁇ where 0 ⁇ 1.
  • the central learning/adaptive algorithm of Eq. (2) may be modified by imposing estimate ⁇ circumflex over (P) ⁇ limits, i.e., ceilings and floors, for particular keywords, either by a system operator or in response to certain user behavior. For example, a strong negative user reaction, e.g., some instruction to never show such type of message again, may impose a ceiling for one or more keywords.
  • training parameters and/or learning rules can be embedded in a given message, which can reflect the correlation strength of the message to the keyword.
  • a first advertisement having three related keywords KW 1 , KW 2 and KW 3 , Keyword KW 1 may be far more closely coupled to the content of the advertisement compared to keywords KW 2 and KW 3 .
  • selection of the advertisement may cause a prediction model to change the respective estimate ⁇ circumflex over (P) ⁇ KW1 far faster than for ⁇ circumflex over (P) ⁇ KW2 and ⁇ circumflex over (P) ⁇ KW3 .
  • the prediction engine may be designed to require that a baseline correlation metric exceed a threshold value to determine relevancy of the target message to the user. For example, in lieu of FIG. 31 it may be desirable to only use keywords associated with estimates that exceed 0.25 and/or are below ⁇ 0.20 to select messages.
  • Eqs (1)-(3) are representative of what is known as an “LMS steepest descent” adaptive/learning algorithm, it should be appreciated that other learning algorithms may be used, such as a Newtonian algorithm or any other known or later-developed learning technique.
  • FIG. 32A and FIG. 32B outline an exemplary operation for a mobile client to perform various learning and predictive processes.
  • the process starts in step 3204 where a set of keywords are assigned.
  • the set of available keywords may be sparse or not sparse and/or arranged in a hierarchical or non-hierarchical/flat relationship.
  • the set of keywords may be downloaded to a mobile client, e.g., a cellular phone or wireless-capable PDA.
  • a set of seed values may be downloaded onto the mobile client.
  • such seed values may include a set of zero values, a set of values determined based upon known demographics of the user, or a set of values determined by any of the other processes discussed above with regard to initial/seed values. Control continues to step 3210 .
  • a set of first messages may be downloaded onto the mobile client, along with the appropriate meta-data, e.g., keywords and (possibly) keyword weights, and/or any number of learning models, e.g., a modified steepest descent algorithm, and/or any number of learning parameters, such as the decay parameter discussed above, ceiling limits, floor limits, context constraints, and so on.
  • the present set of operations allow for messages to be downloaded at the same time as meta-data and other information, in various embodiments messages may be downloaded after the mobile client determines that such messages are suitable via any number of gating or valuation operations. Control continues to step 3212 .
  • step 3212 a number of prediction operations may be performed to predict messages, such as targeted advertisements, that would likely be of interest to a user noting that such a prediction operation could be based on a learned model constructed from the seed values of step 3208 .
  • the desirable message(s) could be displayed (or otherwise presented) on the mobile device.
  • the mobile device could monitor user responses, e.g., observe and possibly store click-through rates, to the displayed message(s). Control continues to step 3220 .
  • a set of one or more learning algorithms may be performed to update (or otherwise determine) the various learned models to establish one or more sets of learned user preference weights.
  • learned models may be provided for a variety of context, may use any number of adaptive processes, such as an LMS operation, may incorporate algorithms and learning parameters for particular messages and so on. Control continues to step 3222 .
  • a set of second/target messages may be downloaded onto the mobile client, along with the appropriate meta-data, and/or any number of learning models, and/or any number of learning parameters.
  • messages may be downloaded after the mobile client determines that such messages are suitable via any number of gating or valuation/prediction operations. Control continues to step 3224 .
  • step 3224 a number of prediction operations may be performed to predict messages, such as targeted advertisements, that would likely be of interest to a user noting that such a prediction operation could be based on the learned model of step 3220 .
  • the desirable message(s) could be displayed (or otherwise presented) on the mobile device.
  • the mobile device could monitor user responses, e.g., observe and possibly store click-through rates, to the displayed message(s). Control then jumps back to step 3220 where after steps 3220 - 3228 may be repeated as necessary or otherwise desirable.
  • a user preference vector may have N dimensions, but only some subset of M dimensions may be relevant to the user.
  • a sparse set of K dimensions can be randomly selected from the N dimensions, and the user preference values associated with the chosen K dimensions may be transmitted. Assume that there are U users in the population for a certain demographic type (such as teenagers). If all U users transmitted all N dimensional values to a server, then each dimension may have available U samples to determine statistics associated with the dimension (such as a mean or variance). However, if only sparse (K-dimensional) components are transmitted, then, on an average, Uk/N samples may be available for each dimension.
  • Cache Miss History Attribute Every time a particular message/ad is requested from a cache and there is no message/ad in the cache satisfying the message/ad type requested, it is a missed opportunity to show an appropriate message/ad to the user. Thus, there is a need to give more weighted value to message that are of the type for which the cache has recorded misses in the recent past.
  • a parameter such as the cache miss state match indicator (FLAG CACHE — MISS — MI ) discussed above, can work to avoid such missed opportunities by aiding message/ad value calculation. In various embodiments, this attribute works to determine whether a new prospective message matches the most recent recorded cache misses.
  • This flag may be reset once the message is accessed by an application from the cache and served to the user. If a new message is selected for cache entry, the cache miss entry can be removed from the list of recorded cache misses.
  • Filter rules may be used by a System Operator to drive the operation of a filtering agent. This allows the System Operator to control the functionality of the filtering agent in a dynamic fashion. Filter rules may be of different types and used to drive different functionalities of the filtering subsystem. Some typical use cases may include:
  • gating and message selection sub-processes might be implemented by different agents that exist either on a server or on a client.
  • the following sections below discuss the possible architectures for message filtering based on different ad distribution mechanisms.
  • FIG. 33 is an illustration of a Multicast/Broadcast Message Distribution scenario using a W-AT 100 and a multicast/broadcast message distribution server 150 -A.
  • messages e.g., ads
  • respective metadata and messages filtering rules can be distributed by a message delivery network over a broadcast or multicast channel to a number of users. Consequently, the filtering and caching of messages targeted to the user profile of the user may take place on the W-AT 100 along with any gating and selection sub-processes of the filtering process.
  • Unicast Message Distribution There are a number of different protocols that can be used to implement unicast fetch of messages from a message distribution server. Based on the information available at such a server, the gating and selection process can reside on either the server or the various mobile devices. The following is a discussion on some of the protocols and the corresponding message filtering architecture that may be implemented in each case.
  • FIG. 34 illustrates a first exemplary unicast message distribution scenario using W-AT 100 and a unicast message distribution server 150 -B.
  • the W-AT 100 can send a “message pull” request to the server 150 -B whereby the server 150 -B can respond with all the messages available within the system.
  • This approach can hide the mobile device's user profile from the server 150 -B by generating and maintaining the profile on the W-AT 100 .
  • it could be expensive to deliver messages to a client over a unicast session if there is a likelihood of a significant portion of the messages being rejected because of non-match with the mobile device's user profile.
  • the filtering and caching of messages targeted to the user profile of the W-AT 100 may take place on the W-AT 100 along with the gating and selection sub-processes of the filtering process.
  • FIG. 35 illustrates a second unicast distribution scenario using W-AT 100 and unicast message distribution server 150 -C.
  • a user profile can be generated on the W-AT 100 but can be in-sync with server 150 -C in that identical copies of the user profile can reside on both devices 100 and 150 -C.
  • the device profile of W-AT 100 may also be in-sync with the server 150 -C and hence, upon receiving a message pull request from the W-AT 100 , the server 150 -C can readily push only targeted messages to the device.
  • the gating process as well as parts of the selection process based on determining whether the messages can be targeted towards the user profile of the W-AT 100 —can be implemented on the server 150 -C.
  • the message value determination and replacement of old messages by higher-valued new messages can be implemented on the W-AT 100 .
  • any syncing procedures of the user and device profile between the W-AT 100 and the server 150 -C may take place out-of-band using a separate protocol, or in certain embodiments the profiles might be included in the message pull request from the client.
  • FIG. 36 illustrates a third exemplary unicast message distribution scenario using W-AT 100 and unicast message distribution server 150 -D.
  • a user profile can be maintained on the W-AT 100 , but only the device profile is synced with the server 150 -D while the user profile remains only within W-AT 100 .
  • the gating process can be implemented on the server 150 -D, and the server 150 -D may push only messages to the W-AT 100 that have cleared the gating process.
  • Part of the gating process based on system operator specified filters (if any) that require the user's profile, can be implemented at the W-AT 100 . Further, the selection process can be implemented completely at the W-AT 100 .
  • the sync of the device profile between the W-AT 100 and the server 150 -D might take place out-of-band using a separate protocol or the profile might be included in the ad pull request from the client.
  • FIG. 37 illustrates a fourth unicast message distribution scenario using W-AT 100 and unicast message distribution server 150 -E.
  • the server 150 -E can respond back with metadata for messages that clear the appropriate gating process.
  • the gating process can be implemented on the server 150 -E.
  • the selection process can be implemented at the W-AT 100 using the metadata provided by the server 150 -E.
  • Part of the gating process based on system operator specified filters (if any) that require the user's profile, can be implemented at the W-AT 100 .
  • the W-AT 100 may respond to server 150 -E with a message selection requests for those messages that the W-AT 100 decides to display or store in its cache based upon the selection process, and the server 150 -E may provide those selected messages to the W-AT 100 .
  • the device profile or the gating parameters might be included in an initial message pull request by the W-AT 100 , or alternatively might be synchronized between the W-AT 100 and the server 150 -E out-of-band using a separate protocol.
  • Location information may often be used to derive indicators of personal demographics.
  • location data may sometimes be a better indication of demographic data concerning the user than billing information.
  • billing information may not include sufficient data to indicate the desired demographics.
  • home demographics may be only partially indicative of the message-related interests of the user. If, for example, the user maintains two residences, or tends to frequent particular locations, this may not be indicated by home demographics. Thus, for example, services and products related to a particular work or recreational location may not be reflected by the home-location derived demographics of a user, but still be very useful.
  • a user may not wish to release his/her location information in order to preserve privacy or may consider it overly intrusive.
  • a mobile client by retaining the capability to gather location information and perform location-based matching by a mobile client, it is possible to attain the information required for demographic targeting within the mobile device and still preserve privacy.
  • an appropriately enabled mobile device such as a cell phone with access to GPS information
  • the appropriate information for the user's recreational interest may be derived and/or synthesized without bothering the user and/or breaching the user's privacy.
  • This information may then be used to derive and/or update a user profile resident to the mobile device, which in turn may be used to determine which targeted content messages may be downloaded and/ore displayed on the mobile device.
  • this can result in placement of advertising and other information in a manner appropriate to the location information associated with a user, based on actual detected locations, but without providing the location information to an external agent.
  • location information may be stored using a database resident to a mobile device.
  • the stored data may include raw location data, but also in various embodiments include data regarding: specific locations area locations, clusters of locations, path information from various locations to other locations, location-types in combination with values associated with time intervals, and time probability distributions of specific location types.
  • user action may be insufficient to indicate a particular activity, but user actions may be relevant if such actions can be linked with one or more various sets of location data.
  • user actions may be relevant if such actions can be linked with one or more various sets of location data.
  • Taking the example of a person who frequents a recreation area but usually enters the recreation area by entering a particular roadway. Data concerning use of that roadway would not by itself be indicative of much beyond the use and existence of the roadway, and would not by itself have any associations with the recreation area.
  • By coupling/correlating the individual's location history and the present action of entering the roadway it is possible to establish a statistically significant probability that the individual is en route to the recreational area.
  • particular location information can be correlated with activities associated with other particular locations.
  • Continued examples include recreational areas, parts of a city, entertainment locations (especially in combination with time-of-day information), geographical location in combination with time-of-day associated with work, and locations associated with shopping. These can be combined with identification of clusters of locations and time intervals.
  • the locations can be used in combination with path analysis, which can be useful in establishing an association of present location (or movement) with other stored data, e.g., present location, location history and path activity can be used to identify a likelihood of a particular activity, and thus enable a message provider to target messages before a user engages in a particular activity.
  • the mobile client may determine that the user has left work and is on-route to a shopping center the user frequents.
  • a MAS or other targeted content delivery system
  • a significant aspect of the system may include that tracking of an individual may be performed within the mobile device and retained within the mobile device.
  • no external party is privy to the tracking information.
  • the profiling necessary to match the tracking information associated with various targeted content can be performed within the mobile device. Again, by limiting personal information to a user's mobile device, it is likely that the user may find this form of profiling acceptable because it is not performed externally.
  • a mobile client with resources available in other devices, such as a GPS-based navigation device of many automobiles.
  • GPS and other information may be shared.
  • such an automobile and mobile client may communicate using a Bluetooth or similar wireless interface commonly found in such devices.
  • the mobile device's resident user profile may be updated without the expense of a GPS system built in to the mobile device.
  • a particular mobile device may derive location information from a variety of alternate sources, such as a remote server or other nearby device, to receive location information.
  • a mobile client may come into contact with an 802.11 network residing in a coffee shop, or perhaps a string of local wireless networks within a city whose locations are known or capable of being derived, to determine location information.
  • a mobile client can choose the source of information based on the energy level of the mobile client/device, e.g., a low battery charge. Also note that location history can be obtained based on periodic measurements where the period of measurements is allowed to vary, or based on random measurements, or a combination of random and periodic measurements. A mobile client may also chose to change the rate of GPS capture based on available energy, e.g., slow the GPS capture rate with intermittent power down on low battery conditions, as well as change the rate that it might tap into other available data sources, e.g., the accelerometer and/or speedometer of an automobile to which the mobile client has access.
  • FIGS. 38A-38H depict information screens 3800 -A . . . 3800 -H captured by a GPS-enabled cellular phone of a particular user displayed with various points of interest.
  • each information screens 3800 -A . . . 3800 -H includes a map 3810 , a set of controls 3820 , a calendar display 3830 , a daily histogram 3840 and a weekly histogram 3850 .
  • a user may set each control in the set of controls 3820 for establish GPS sampling times and the display of GPS information for the map 3810 , the calendar 3820 and the histograms 3840 and 3850 noting that while histogram 3840 is a daily histogram divided into time slots of one hour and the weekly histogram 3850 is divided into slots of one day, such captured location data may be organized into any number of histograms including a daily histogram showing particular locations, areas, clusters of locations and even information representing past paths taken that the user had experienced over the course of various time periods, e.g., weekdays, weekends, individual days, whole weeks, whole months and so on.
  • the calendar 3830 may also be considered a histogram.
  • a particular location icon such as location 3850 or 3852 of FIG. 38A
  • the data of histograms 3840 and 3842 can change to reflect GPS data commensurate with collected GPS data.
  • a particular location may be identified (either by a mobile client's user or by some estimation software in the mobile client) as a user's residence 3854
  • a particular location may be identified as the user's workplace 3856 .
  • location information captured by a GPS-enabled cellular phone may be used to generate user profile information enabling resident software to determine both: (1) the likelihood that a user will be at a particular location or traveling along a particular path at a given time frame, e.g., an employee be at a work location at 4:00 pm; (2) the likely timeframe that the user will leave a particular starting location at a given time, e.g., the employee leave a work location at 5:00 pm, and (3) the likely timeframe that the user will be at a particular second location or use a path (or set of locations or paths), e.g., the employee use a particular road at 5:30 pm and reach his residence between 6:00 pm and 3:1 pm.
  • likelihood information may be expressed in a large variety of ways.
  • a time likelihood may be expressed as a particular point in time, a Gaussian distribution centered on particular point in time and with a particular variance; a continuous probability distribution function (PDF) having a unique form based on past user activity; a discrete PDF measured in contiguous time periods (“time buckets”) with the time buckets being of equal or unequal size, and so on.
  • PDF probability distribution function
  • an appropriately enabled mobile client may also determine points of interest for the user, such as the user's likely location for his home, work, hobbies, place of religious worship and so on, as well as the likely times that the user will be at such locations and other likelihood information for such points of interest (e.g., likely times of arrival and departure). Such information may then be used to shape or modify user profile information in his mobile client, and as mentioned above, the resultant user profile may be used to determine what information (e.g., advertisements, coupons, etc.) would most likely interest the user, which in turn may lead to specific target information being stored and/or displayed on the mobile client.
  • points of interest for the user such as the user's likely location for his home, work, hobbies, place of religious worship and so on, as well as the likely times that the user will be at such locations and other likelihood information for such points of interest (e.g., likely times of arrival and departure).
  • Such information may then be used to shape or modify user profile information in his mobile client, and as mentioned above, the resultant user profile may be used to determine what
  • FIG. 39 and FIG. 40 depict an exemplary number of operations for an example of a user leaving a work location L W at the end of a work day.
  • the probabilities concerning the various locations i.e., starting location L W and prospective destination locations L 1 -L 8 , along with the probabilities of using the respective paths/roads R 1 -R 8 between locations L 1 -L 8 , can be assumed to be developed using past behavior of the user, sensed using GPS and other technology, and incorporated into the user's mobile client.
  • a user profile in his mobile client can determine that the user is likely to leave work at 5:00-5:15 pm and head to any of prospective destination locations L 1 -L 8 noting that in the present example the probability of heading to locations L 7 -L 8 falls below a particular threshold and should not be considered.
  • the probability of the user heading to location L 1 and L 6 are both 0.1
  • the probability of the user using roads R 7 and R 8 are also both 0.1.
  • the probability that the user uses road R 1 is 0.7.
  • likely routes of the mobile client's user may be based on spatial relationships of the mobile client's current location L W in relation to the most likely destination locations L 1 -L 8 , as well as the spatial relationships between the most likely destination locations L 1 -L 8 .
  • the user profile of the user's mobile client may be formed and updated by correlating past time data of the user's location history to form a time probability distribution of the user's past presence and movement for the work location L W and/or any other location to which the user may have visited; the result being a probability density function (or facsimile thereof) of the presence of the user at a given location as a function of time.
  • Such a user profile may determine any and all of the current most likely probable destinations L 1 -L 6 under consideration by the user as a function of time and/or present location.
  • any of the most probable current destinations may be an amalgam or cluster of a plurality of past identified destinations of the user.
  • location L 5 may actually consist of three separate locations closely spaced together with the assumed location inform being a centroid (based on a weighted geographical average) or general area of the three location.
  • locations L 3 -L 5 might be combined into an amalgam location assuming locations L 3 -L 5 are reasonable proximate/clustered relative to one another.
  • the user's mobile client may determine the most probable destinations based on the time of day, the user's present location and other current observations taken by the mobile client, as well as those past observations incorporated into the user profile.
  • Such “other current observations” may include things such as recent phone and texting activity. For example, if the user receives a call from his wife at 4:30 pm, it may indicate an increase likelihood that the user may need to go to a store before heading home, thus changing the probabilities for the current likely destinations L 1 -L 6 . Similarly, if the user shows no interaction with his mobile client, it may indicate a likelihood that the user may delay his departure from location L W .
  • the probability of heading to any of the various current likely destinations L 1 -L 6 may be updated based on “en route” accumulated measures of location change by the mobile client after leaving the first location L W . That is, as new data is received, the various probabilities may need to be re-assessed. For the example of FIG. 40 , this is reflected in changes in the probabilities of going to destinations L 1 and L 6 , as well as the probability of the user staying at location L W , becomes negligible given that the user is determined to be on road R 1 by his mobile client. Thus, the probabilities of going to destinations L 1 and L 6 or staying at location L W may be discounted from further consideration.
  • the probability of reaching any of locations L 2 , L 3 , L 4 , L 5 , L 8 and L 8 may increase noting that the likelihood of the user reaching location L 2 is near unity (due to its spatial relationship with both the user and the other current destination locations L 3 , L 4 , L 5 , L 8 and L 8 ) even if the user makes no stop at location L 2 .
  • determining a likely transition time e.g., the time of leaving a first location or arriving at another location, may be accomplished using an adaptive weighted allocation based on other en route events.
  • a k th order Markov model (where k is an integer greater than 1) incorporated into the mobile client may be used to determine any of the probabilities discussed above.
  • an exemplary Markov model 4100 is depicted for the user's starting location L W and prospective destination locations L 1 -L 8 of FIG. 39 and FIG. 40 .
  • the locations L W and L 1 -L 8 are interconnected with paths, and each path has a probability P N-M .
  • each probability P N-M can be derived from a user profile and vary as a function of the current location of a user, a transition event and/or time of day.
  • time-varying probabilities P N-N of the user staying at location L N for a given period e.g., the likelihood of the user remaining at a grocery store (upon reaching it) may have a Gaussian distribution centered at 20 minutes with a 10 minute variance.
  • FIG. 42 is diagram of a process flow outlining an exemplary operation for updating the user profile based on an NFC transaction.
  • the process starts in step 4202 where a mobile client may be programmed to sample location information using an available GPS (or other suitable location finding device) and/or any of local wireless cellular networks, local available LANs, and so on, according to predetermined or adaptive sampling frequencies and periods.
  • the captured information may be processed/synthesized to identify points, areas of interest, paths taken or any other location and/or path data.
  • the information may be further processed/synthesized to determine likely locations and/or likely paths for particular time periods—as well as complementary information of likely time periods for a given location or path. Control continues to step 4208 .
  • a user profile residing in the mobile client can be updated using special software resident in the mobile client.
  • user profile information which includes information derived from past observations of the user, may be used to create some form of probability model of the user's likely behavior for a given time of day and current location.
  • the mobile client may derive (directly or using secondary resources, e.g., an automobile's GPS) any and all of the recent/current observation data discussed above, such as location, time, transition/movement, sensor (e.g., speedometer) data, as well as information related to the user's current and/or recent behavior, e.g., the mobile client observes the user sending text messages.
  • the mobile client may process the information of step 4210 and the information within the user profile using any of the techniques discussed above, to identify likely destinations, transition times and/or paths (or changes to previously determined probabilities) that the user will likely take based on the user's current location and time.
  • step 4214 the mobile client may select and/or display information, e.g., advertisements, coupons etc, based on the user profile, the data collected in the previous steps and any probability data derived. Control then jumps back to step 4210 where any or all of steps 4210 - 4214 may be repeated as may be found necessary or desirable.
  • information e.g., advertisements, coupons etc
  • the techniques and modules described herein may be implemented by various means. For example, these techniques may be implemented in hardware, software, or a combination thereof.
  • the processing units within an access point or an access terminal may be implemented within one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing W-ATs (DSPDs), programmable logic W-ATs (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, other electronic units designed to perform the functions described herein, or a combination thereof.
  • ASICs application specific integrated circuits
  • DSPs digital signal processors
  • DSPDs digital signal processing W-ATs
  • PLDs programmable logic W-ATs
  • FPGAs field programmable gate arrays
  • processors controllers, micro-controllers, microprocessors, other electronic units designed to perform the functions described herein, or a combination thereof.
  • the techniques described herein may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein.
  • the software codes may be stored in memory units and executed by processors or demodulators.
  • the memory unit may be implemented within the processor or external to the processor, in which case it can be communicatively coupled to the processor via various means.
  • the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium.
  • Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another.
  • a storage media may be any available media that may be accessed by a computer.
  • such computer-readable media may comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to carry or store desired program code in the form of instructions or data structures and that may be accessed by a computer.
  • any connection is properly termed a computer-readable medium.
  • the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (“DSL”), or wireless technologies such as infrared, radio, and microwave
  • the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium.
  • Disk and disc includes compact disc (“CD”), laser disc, optical disc, digital versatile disc (“DVD”), floppy disk, High Definition DVD (“HD-DVD”) and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.

Abstract

Methods and systems for determining a suitability for a mobile client to display information are disclosed. A particular exemplary method includes receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, monitoring user interaction of the respective first messages on the mobile client, determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, receiving a set of target keywords associated with a target message, performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and displaying the target message on the mobile client dependent upon the matching parameters.

Description

  • This Application both claims to priority, and incorporates the entire content of, U.S. Provisional Patent Application Nos. 60/988,029 entitled “METHOD AND SYSTEM FOR USER PROFILE MATCH INDICATION IN A MOBILE ENVIRONMENT” and filed on Nov. 14, 2007; 60/988,033 entitled “METHOD AND SYSTEM FOR KEYWORD CORRELATION IN A MOBILE ENVIRONMENT” and filed on Nov. 14, 2007; 60/988,037 entitled “METHOD AND SYSTEM FOR USER PROFILE MATCH INDICATION IN A MOBILE ENVIRONMENT” and filed on Nov. 14, 2007, and 60/988,045 entitled “METHOD AND SYSTEM FOR MESSAGE VALUE CALCULATION IN A MOBILE ENVIRONMENT” and filed on Nov. 14, 2007. This Application also incorporates the entire content of U.S. Non-Provisional patent application Ser. No. ______: (Qualcomm Attorney Docket No. 071913U1) entitled “USER PROFILE MATCH INDICATION IN A MOBILE ENVIRONMENT METHODS AND SYSTEMS” and filed on ______; Ser. No. ______ (Qualcomm Attorney Docket No. 071913U2) entitled “METHOD AND SYSTEM USING KEYWORD VECTORS AND ASSOCIATED METRICS FOR LEARNING AND PREDICTION OF USER CORRELATION OF TARGETED CONTENT MESSAGES IN A MOBILE ENVIRONMENT” and filed on ______; Ser. No. ______ (Qualcomm Attorney Docket No. 071913U3) entitled “METHOD AND SYSTEM FOR USING A CACHE MISS STATE MATCH INDICATOR TO DETERMINE USER SUITABILITY OF TARGETED CONTENT MESSAGES IN A MOBILE ENVIRONMENT” and filed on ______; Ser. No. ______ (Qualcomm Attorney Docket No. 071913U4) entitled “METHOD AND SYSTEM FOR MESSAGE VALUE CALCULATION IN A MOBILE ENVIRONMENT” and filed on ______; Ser. No. ______ (Qualcomm Attorney Docket No. 071913U5) entitled “METHOD AND SYSTEM USING KEYWORD VECTORS AND ASSOCIATED METRICS FOR LEARNING AND PREDICTION OF USER CORRELATION OF TARGETED CONTENT MESSAGES IN A MOBILE ENVIRONMENT” and filed on ______.
  • FIELD OF THE DISCLOSURE
  • This disclosure relates to wireless communications. In particular, the present disclosure relates to wireless communications systems usable for targeted-content-message processing and related transactions.
  • BACKGROUND
  • Mobile Targeted-Content-Message (TCM)-enabled systems can be described as systems capable of delivering targeted content information, such as local weather reports and advertisements targeted to a particular demographic, to wireless communication devices (WCDs), such as cellular telephones or other forms of wireless access terminals (W-ATs). Such systems may also provide a better user experience by presenting non-intrusive targeted-content-messages that are likely to be of interest to a user.
  • An example of a mobile TCM-enabled system is a M-TCM-PS capable of delivering advertisements to wireless communication devices (WCDs). Generally, a M-TCM-PS can provide such things as an advertisement sales conduit for a cellular provider to provide advertisements on a W-AT, as well as some form of analytical interface to report back on the performance of various advertisement campaigns. A particular consumer benefit of mobile advertising is that it can provide alternate/additional revenue models for wireless services so as to allow more economical access to the wireless services to those consumers willing to accept advertisements. For example, the revenue generated through advertising may allow W-AT users to enjoy various services without paying the full subscription price usually associated with such services.
  • In order to increase the effectiveness of TCMs on W-ATs, it can be beneficial to provide targeted information, i.e., TCMs which are deemed likely to be well received by, and/or of likely interest to, a particular person or a designated group of people.
  • Targeted-Content-Message (TCM) information can be based on immediate needs or circumstances, such as a need to find emergency roadside service or the need for information about a travel route. Targeted-Content-Message information can also be based on specific products or services (e.g., games) for which a user has demonstrated past interest, and/or based on demographics, for example, a determination of an age and income group likely to be interested in a particular product. Targeted Advertisements are an example of TCMs.
  • Targeted advertisements can provide a number of advantages (over general advertisements) including: (1) in an economic structure based on cost per view, an advertiser may be able to increase the value of his advertising budget by limiting paid advertising to a smaller set of prospects; and (2) as targeted advertisements are likely to represent areas of interest for a particular user, the likelihood that users will respond positively to targeted advertisements increases substantially.
  • Unfortunately, the information that makes some forms of targeted advertising possible may be restricted due to government regulations and the desire of people to limit the dissemination of their personal information. For example, in the US, such government restrictions include the Graham-Leach-Bliley Act (GLBA), Title 47 of the United States Code, Section 222—“Privacy of Customer Information.” Common carriers also may be restricted from using personal information about their subscribers for marketing purposes. For example, the GLBA prohibits access to individually identifiable customer information, as well as the disclosure of location information, without the express prior authorization of the customer.
  • Thus, new technology for delivering targeted content messages in a wireless communication environment is desirable.
  • SUMMARY OF THE DISCLOSURE
  • In an exemplary embodiment, a method for determining a suitability for a mobile client to display information includes receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, monitoring user interaction of the respective first messages on the mobile client, determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, receiving a set of target keywords associated with a target message, performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and displaying the target message on the mobile client dependent upon the matching parameters.
  • In another exemplary embodiment, a mobile client configured to display information, includes a receiving circuit configured to receive a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message, a monitoring agent configured to monitor user interaction of the respective first messages on the mobile client, a determining agent configured to determine a user selection rate for each unique first keyword of the plurality of sets of first keywords, a filtering agent configured to perform one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and a display configured to display the target message on the mobile client dependent upon the matching parameters.
  • In yet another exemplary embodiment, a mobile client configured to display information includes a receiving circuit configured to receive a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message, a monitoring means for monitoring user interaction of the respective first messages on the mobile client, a determining means for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, a filtering means for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and a display configured to display the target message on the mobile client dependent upon the matching parameters.
  • In still another exemplary embodiment, an apparatus for determining a suitability for a mobile client to display information includes one or more processors located on the mobile client, and one or more electronic memories each readable by at least one processor, the electronic memories containing instructions for: receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, monitoring user interaction of the respective first messages on the mobile client, determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, receiving a set of target keywords associated with a target message, performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and displaying the target message on the mobile client dependent upon the matching parameters.
  • In yet another exemplary embodiment a computer program product includes a computer-readable medium that in turn includes instructions for receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, instructions for monitoring user interaction of the respective first messages on the mobile client, instructions for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords, instructions for receiving a set of target keywords associated with a target message, instructions for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters, and instructions for displaying the target message on the mobile client dependent upon the matching parameters.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The features and nature of the present disclosure will become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which reference characters identify corresponding items and processes throughout.
  • FIG. 1 is a diagram showing the interaction between an exemplary wireless access terminal (W-AT) and an advertising infrastructure. An advertising infrastructure is an example of a targeted-content-message-processing infrastructure.
  • FIG. 2 is schematic block diagram showing the operation of an exemplary W-AT having an on-board user profile generation agent.
  • FIG. 3 is a schematic block diagram showing an exemplary operation of a data transfer of a user profile generation agent.
  • FIG. 4 is a schematic block diagram handling an exemplary request for profile data processing.
  • FIG. 5 is a schematic block diagram showing an exemplary operation of a user profile generation agent.
  • FIG. 6 is a flowchart outlining an exemplary operation for generating and using a user profile.
  • FIG. 7 is a flowchart outlining another exemplary operation for generating and using a user profile.
  • FIG. 8 is a diagram illustrating the use of a one-way hash function for client identity protection when identifiable data is transferred to a mobile advertising/mobile targeted-content-message processing server.
  • FIG. 9 is a diagram illustrating data flow implemented by a proxy server for anonymizing identifiable data transferred to a mobile advertising server/mobile targeted-content-message processing server.
  • FIG. 10 is a diagram illustrating a second data flow implemented by a proxy server for anonymizing identifiable data transferred to a mobile advertising server mobile targeted-content-message processing server.
  • FIG. 11 depicts a communication protocol for advertisement distribution in a mobile targeted content message-enabled network.
  • FIG. 12 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 13 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 14 depicts another communication protocol for targeted-content-message distribution in a mobile message delivery-enabled network.
  • FIG. 15 depicts a timeline for a first communication protocol for downloading advertising content according to “contact windows” approach.
  • FIG. 16 depicts an alternate timeline for a communication protocol for downloading advertising content according to a defined time schedule.
  • FIG. 17 depicts an alternate timeline for a first communication protocol for downloading content according to a defined time schedule.
  • FIG. 18 is an illustration of a message filtering process.
  • FIG. 19 is an illustration of message filtering process components.
  • FIG. 20 is an illustration of a gating process.
  • FIG. 21 is an illustration of a random sampling logic diagram.
  • FIG. 22 is an illustration of a one-way function based sampling logic diagram.
  • FIG. 23 is an illustration of selection process flow diagram.
  • FIGS. 24A and 24B depict a flowchart of a message selection process.
  • FIG. 25 is a flow chart illustrating an exemplary User Profile Match Indicator (MI) process.
  • FIG. 26 is a block diagram illustrating an exemplary user profile match indicator.
  • FIG. 27 is a flow chart of an exemplary keyword correlation process.
  • FIG. 28 block diagram illustrating an exemplary learning and prediction engine.
  • FIG. 29 block diagram illustrating an exemplary learning and prediction engine in context with other elements of a mobile client.
  • FIG. 30A depicts an exemplary hierarchical keyword organization.
  • FIG. 30B depicts an exemplary non-hierarchical/flattened keyword organization.
  • FIG. 31 depicts a series of graphs representing the expected performance of an exemplary learning process for enabling a mobile client to adapt to user preferences.
  • FIGS. 32A and 32B depict a block diagram illustrating an exemplary process for enabling a mobile client to adapt to user preferences.
  • FIG. 33 is an illustration of a multicast/broadcast message distribution.
  • FIG. 34 is an illustration of an exemplary unicast message distribution protocol.
  • FIG. 35 is an illustration of another exemplary unicast message distribution protocol.
  • FIG. 36 is an illustration of yet another exemplary unicast message distribution protocol.
  • FIG. 37 is an illustration of still another exemplary unicast message distribution protocol.
  • FIGS. 38A-38H depict various captured location data with historical information for a particular user.
  • FIG. 39 and FIG. 40 depict an exemplary set of locations and paths for a user.
  • FIG. 41 is an exemplary Markov Model for the set of locations and paths of FIGS. 39 and 40.
  • FIG. 42 is diagram of a process flow outlining an exemplary operation for updating the user profile based captured location information.
  • DETAILED DESCRIPTION
  • The disclosed methods and systems below may be described generally, as well as in terms of specific examples and/or specific embodiments. For instances where references are made to detailed examples and/or embodiments, it should be appreciated that any of the underlying principals described are not to be limited to a single embodiment, but may be expanded for use with any of the other methods and systems described herein as will be understood by one of ordinary skill in the art unless otherwise stated specifically.
  • The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any aspect described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects.
  • For the purpose of example, the present disclosure is often depicted as being implemented in (or used with) a cellular telephone. However, it is to be appreciated that the methods and systems disclosed below may relate to both mobile and non-mobile systems including mobile phones, PDAs and lap-top PCs, as well as any number of specially equipped/modified music players (e.g., a modified Apple iPOD®), video players, multimedia players, televisions (both stationary, portable and/or installed in a vehicle), electronic game systems, digital cameras and video camcorders.
  • The terms and respective definitions/descriptions below are provided as a reference to the following disclosure. Note, however, that when applied to certain embodiments, some of the applied definitions/descriptions may be expanded or may otherwise differ with some of the specific language provided below as may be apparent to one of ordinary skill and in light of the particular circumstances.
  • TCM—Targeted-Content-Message. An advertisement can be an example of a Targeted-Content-Message.
  • M-TCM-PS—Mobile Targeted-Content-Message Processing System
  • MAS—Mobile advertising system, which may be considered a form of M-TCM-PS.
  • UPG—User Profile Generation Agent
  • M-TCM—Mobile TCM-Enabled Client
  • MAEC—Mobile advertising enabled client. This can be an example of a Mobile TCM-Enabled Client
  • Mobile TCM Provider (M-TCM-P)—A person or an entity that may want to display a targeted-content-message through a targeted-content-message processing system.
  • Advertiser—A person or an entity that may want to display advertisements through a mobile advertising system (MAS). An advertiser may provide the advertisement data along with respective targeting and playback rules, which may in some instances form advertisement metadata to a MAS. An advertiser is an example of a Mobile TCM Provider.
  • TCM Metadata—A term used to identify data that can be used to provide additional information about a respective Targeted-Content-Message (TCM).
  • Advertisement Metadata—A term used to identify data that may be used to provide additional information about a respective advertisement. This may include, but is not limited to, mime type, advertisement duration, advertisement viewing start time, advertisement viewing end time, etc. Respective advertisement targeting and playback rules provided by the advertiser may also get attached to an advertisement as metadata for the advertisement. Advertisement Metadata is an example of TCM metadata.
  • Application Developer—A person who or an entity that develops an application for the mobile advertising enabled client (MAEC) that can feature advertisements.
  • System Operator—A person who or entity that operates a MAS.
  • Third Party Inference Rule Provider—A third party (other than a system operator) who may provide user profile inference rules to be used by a User Profile Generation Agent
  • User Profile Generation Agent—A functional unit at the client that may receive various pertinent data, such as advertisement inference rules, user behavior from a metric collection agent, location data from a GPS, explicit user preferences entered by a user (if any) and/or user behavior from other client applications, then generate various user profile elements. A User Profile Generation Agent may continuously update a profile based upon information gathered that may be used to characterize user behavior.
  • User Behavior Synthesizer—A functional device or agent within a User Profile Generation Agent that may be used to receive a variety of data, such as user behavior information, location information and user profile inference rules to generate synthesized profile attributes.
  • Profile Element Refiner—A functional device or agent within a User Profile Generation Agent that may receive profile attributes generated by a user behavior synthesizer as well as a number of user profile inference rules. A Profile Element Refiner may refine profile attributes, process them through queries sent to a profile attribute processor, and generate user profile elements.
  • Profile Attribute Processor—A server and/or resident agent of a server that may process profile attribute requests that may require data-intensive lookups, and then respond with refined profile attributes.
  • TCM Filtering Agent—A client agent that may receive a number of TCMs with their respective meta-data, TCM targeting rules and TCM filtering rules, then store some or all of the TCMs in a TCM-cache memory. The filtering agent may also take a user profile as input from the User Profile Generation Agent.
  • Advertisement Filtering Agent—A client agent that may receive a number of advertisements with their respective metadata, advertisement targeting rules and advertisement filter rules, then store some or all of the received advertisements in an advertisement cache memory. The filtering agent may also take a user profile as input from the User Profile Generation Agent. An advertising filtering agent is an example of a TCM filtering agent.
  • TCM Cache Manager—A client agent that can maintain a targeted content-message cache. A cache manager may take cached targeted content-messages from a filtering agent, and respond to content-message requests from other applications on the access terminal. Note that, for the present disclosure, the term ‘cache’ can refer to a very broad set of memory configurations, include a single storage device, a set of distributed storage devices (local and/or not local) and so on. Generally, it should be appreciated that the term ‘cache’ can refer to any memory usable to speed up information display, processing or data transfer.
  • Advertisement Cache Manager—A client agent that can maintain an advertisement cache. A cache manager may take cached advertisements from a filtering agent and respond to advertisement requests from other applications on the access terminal. An advertisement cache manager is an example of a TCM cache manager.
  • User Profile Attributes—User behavior, interests, demographic information, and so on that may be synthesized by a user behavior synthesizer to form profile attributes, which may be viewed as intermediate pre-synthesized forms of data that may be further processed and refined by a profile element refiner into more refined user profile elements.
  • User Profile Elements—Items of information used to maintain a user profile, which may include various types of data useful to categorize or define the user's interests, behavior, demographic, etc.
  • TCM Targeting Rules—These may include rules related to the presentation of a targeted-content-message specified by a Mobile TCM Provider.
  • Advertisement Targeting Rules—These may include rules specified by advertisers to impose rules/restrictions on how advertisements may be displayed and/or rules to target an advertisement towards a particular segment of users. They may be specific to a number of criteria, such as an advertisement campaign or advertisement group. Advertisement Targeting Rules are an example of TCM Targeting Rules.
  • TCM Playback Rules—These can include display rules specified by a client application while querying a TCM Cache Manager for TCMs to display in the context of their application.
  • Advertisement Playback Rules—These can include display rules specified by a client application while querying an Advertisement Cache Manager for advertisements to display in the context of their application. Advertisement Playback Rules are an example of TCM Playback Rules.
  • TCM Filter Rules—These can include rules upon which TCMs may be filtered. Typically, a system operator may specify these rules.
  • Advertisement Filter Rules—These can include rules upon which advertisements may be filtered. Typically, a system operator may specify these rules. Advertisement Filter Rules are an example of TCM-Filter-Rules.
  • User Profile Element Inference Rules—These can include rules, specified by a system operator (and/or a third party), that may be used to determine one or more processes usable to build a user profile from demographic and behavioral data.
  • TCM Telescoping—A display or presentation function for a TCM whereby additional presentation material may presented to a user in response to a user request.
  • Advertisement Telescoping—An advertisement display or presentation function whereby additional presentation material may be presented to a user in response to a user request. Advertisement Telescoping is an example of TCM telescoping.
  • As mentioned above, various regulations regarding telecommunications and privacy can make the delivery of messages with targeted content difficult. However, the present disclosure can provide a variety of solutions to deliver targeted content to wireless access terminals (W-ATs), e.g., cellular phones, while paying attention to privacy concerns.
  • One of the many approaches of this disclosure used to alleviate privacy issues includes offloading a variety of processes onto a user's W-AT that may, in turn, be used to generate a set of information that likely characterizes the user, i.e., it can create a “user profile” of the user on the W-AT itself. Accordingly, targeted-content-messages, such as advertisements and other media, may be directed to the user's W-AT based on the user's profiles without exposing potentially sensitive customer information to the outside world.
  • The various disclosed methods and systems may be used in a Mobile TCM Processing System (M-TCM-PS) (and, in particular, in a Mobile Advertising System (MAS)), which for the present disclosure may include an end-to-end communication system usable to deliver targeted-content-messages (or in particular, advertisements) to TCM-Enabled W-ATs (or in particular Mobile Advertising Enabled W-ATs). A M-TCM-PS may also provide an analytical interface capable of reporting on the performance of a particular advertisement campaign. Accordingly, an appropriately constructed M-TCM-PS may provide a better consumer experience by presenting only non-intrusive advertisements that are likely to be of interest to consumers.
  • While the following examples are generally directed to content, such as commercial advertising, a broader scope of directed content is envisioned. For example, instead of directed advertisements, content such as stock reports, weather reports, religious information, news and sports information specific to a user's interests, and so on is envisioned within the bounds of this disclosure. For example, while directed content may be an advertisement, a score for a sports event and a weather report may just as easily be directed content. Accordingly, devices such as advertising servers may be viewed as more general content servers, and advertising-related agents and devices may be more generally thought of as content-related agents and servers. All further discussion is provided in the context of advertisements as an example of a TCM (Targeted Content Message), and it should be noted that such discussion is applicable to Targeted-Content-Messages in general.
  • FIG. 1 is a diagram of some of the various functional elements of an M-TCM-PS showing the interaction between a TCM-enabled W-AT 100 with a communication network having an advertising infrastructure. As shown in FIG. 1, the exemplary M-TCM-PS includes the TCM-enabled mobile client/W-AT 100, a radio-enabled network (RAN) 190 and an advertising infrastructure 150 embedded in the network associated with the wireless WAN infrastructure (not shown in FIG. 1). For example, the messaging infrastructure could be available at a remote server not geographically co-located with a cellular base station in the wireless WAN.
  • As shown in FIG. 1, the W-AT can include a client applications device 110, a client message delivery interface 112, a metric collection agent 120, a message caching manager 122, a message filtering agent 124, a metric reporting agent 126, a message reception agent 120 and a data service layer device 130. The message delivery infrastructure 150 can include a TCM sales agent 160, an analytics agent 162, a message delivery server interface 164, a message ingestion agent 170, a message bundling agent 174, a message distribution agent 176, a metric database 172, a metric collection agent 178, and having a proxy server 182.
  • In operation, the “client side” of the M-TCM-PS can be handled by the W-AT 100 (depicted on the left-hand side of FIG. 1). In addition to traditional applications associated with W-ATs, the present W-AT 100 may have TCM-related applications at the applications level 110, which in turn may be linked to the rest of the M-TCM-PS via a client advertisement interface 112. In various embodiments, the client message delivery interface 112 may provide for metrics/data collection and management. Some of the collected metrics/data may be transferred to the metric reporting agent 126 and/or to the W-AT's data service layer 130 (via the metric collection agent 120), without exposing individually identifiable customer information, for further distribution to the rest of the M-TCM-PS.
  • The transferred metrics/data may be provided through the RAN 190 to the message delivery infrastructure 150 (depicted on the right-hand side of FIG. 1), which for the present example includes a variety of TCM-related and privacy-protecting servers. The message delivery infrastructure 150 can receive the metrics/data at a data service layer 180, which in turn may communicate the received metrics/data to a number of metrics/data collection servers (here metric collection agent 178) and/or software modules. The metrics/data may be stored in the metric database 172, and provided to the message delivery server interface 164 where the stored metrics/data may be used for marketing purposes, e.g., advertising, sales and analytics. Note that information of interest may include, among other things, user selections at a W-AT and requests for advertisements executed by the W-AT in response to instructions provided by the message delivery infrastructure 150.
  • The message delivery server interface 164 can provide a conduit for supplying advertisements (advertising ingestion), bundling advertisements, determining a distribution of advertisements and sending advertising through the data service layer 180 of the message delivery infrastructure 150 to the rest of the M-TCM-PS network. The a message delivery infrastructure 150 can provide the W-AT 100 with the appropriate TCMs, and metadata for the TCMs. The W-AT 100 can be instructed by the message delivery infrastructure 150 to select TCMs based on any available metadata according to rules provided by the message infrastructure 150.
  • As mentioned above, the exemplary W-AT 100 may be enabled to generate, in whole or in part, a user profile for the W-AT's user that, in turn, may be useful to enable the M-TCM-PS to deliver TCMs of likely interest to the user. This may result in better “click-through rates” for various advertisement campaigns and other TCM delivery campaigns. However, as mentioned above, generating a user profile may raise privacy concerns because of the potentially sensitive nature of data that may reside in the user profile.
  • Nevertheless, as will be shown below in the various device and system embodiments, privacy concerns may be alleviated by enabling a user's W-AT to generate a user profile while subsequently limiting the user profile to the confines of the user's W-AT except in very limited (and controlled) circumstances.
  • FIG. 2 is a block diagram showing operational details of the exemplary W-AT of FIG. 1 configured to generate and use a user profile. As shown in FIG. 2, the exemplary W-AT includes a processing system capable of processing a number of applications including a number of core client applications and a client message delivery interface. Note that some components, such as the message reception agent 128 and data service layer 130, are omitted from FIG. 2 for simplicity of explanation for the functions relevant to FIG. 2. The exemplary W-AT 100 of FIG. 2 is shown having a platform specific adaptation interface 111 between the client message delivery interface 112 and the client applications device 110, and a message filtering agent 124 having a user profile generation agent 210 and a client message filtering agent 220 responsive to the user profile generation agent 210. A cache memory 240 is shown in communication with the cache manager 122. External devices, e.g., profile attribute processor 270, system operator (or 3rd party) 280 and message sales interface 164, are shown in communication with the client message filtering agent 124. Devices 270, 280 and 164 are generally not part of a W-AT, but likely to reside in another portion of a M-TCM-PS network.
  • While the various components 110-240 of the W-AT 100 are depicted as separate functional blocks, it should be appreciated that each of these functional blocks may take a variety of forms including separate pieces of dedicated logic, separate processors running separate pieces of software/firmware, collections of software/firmware residing in a memory and being operated upon by a single processor, and so on.
  • In operation, the client applications device 110 may perform any number of functional applications useful for telecommunications (e.g., calls and text messaging) or other tasks (e.g., games) using the platform specific adaptation interface 111 to interface with the client message delivery interface 112. The client message delivery interface 112, in turn, can be used to allow the W-AT 100 to perform a number of useful processes, such as monitor user behavior and pass user-related information to the user profile generation agent 210.
  • In addition to receiving information directly from the client applications interface, the user profile generation agent 210 may accrue user behavior information from the metrics collection agent 120, which itself may receive the same or different information from the client message delivery interface 112. Examples of user behavior may include TCM-related responses, such as advertisement clicks and other metrics indicating types and frequency of usage. Other user behavior information may include direct user preferences or authorizations.
  • The metrics collection agent 120 may provide metrics/data to the metrics reporting agent 126, which in turn may provide the metrics/data information to other components of M-TCM-PS (discussed below) that may be internal or external to a W-AT.
  • The profile attribute processor 270 can process incoming profile attribute processing requests from the W-AT 100 that require (or can otherwise benefit from) data-intensive lookups and respond with refined profile attributes to the user profile generation agent 210.
  • One function of the user profile generation agent 210 may include providing TCMs that may be provided to the W-AT's user in accordance with relevant filter rules, as well as TCM data and TCM metadata from the sales interface 164. The filtering agent 220 may also provide filtered messages to the cache manager 122, which in turn may store and later provide such messages (via cache memory 240) for presentation to the user.
  • A user profile generation agent can be any collection of hardware and/or software residing in a Mobile Advertising Enabled W-AT that can be used to collect user behavior information. Potential information sources may include, but are not limited to, applications residing on the user's W-AT, public information available in various accessible databases, previous user responses to advertisements, location data from a resident GPS radio and explicit user preferences entered by the user (if any). Any user profile information gathered may then be processed/synthesized to generate user profile attributes or elements, which may better characterize the user while using less memory resources.
  • In various embodiments, user profile inference rules provided by a system operator (and/or a third party) may drive the particular actions of a W-AT's user profile generation agent. Note that these rules may be of a number of types, including: (1) Basic Rules, which include actions to be performed by a user profile generation agent on a pre-determined schedule associated with each action; and (2) Qualified Rules, which include “action(s)” that are qualified by a “condition”, where the “condition” may define a behavior that needs to be true, and the “action” may define an action taken by a rule engine of the user profile generation agent when the condition is detected to be true. Such rules may be useful in inferring information from specific user actions or behavior.
  • For example, a simple rule for a user profile generation agent might be to store GPS derived location information for the user's W-AT every five minutes. An associated rule could be that the location most frequented within a 09:00-17:00 time range in the day be marked as the user's likely work location.
  • By way of a second example, a rule qualified by a condition might be to add a “game” category to the user's list of interests if the user often spends more than 30 minutes a day in the gaming applications on his W-AT.
  • Also note that the user profile generation agent may also take as input user preferences including user selection concerning express authorization of the user to derive a profile using location data, other authorizations made by the user and other specific information entered by the user. For example, the user might input his preference to view travel-related advertisements.
  • Various rule-driven approaches incorporated in a user's W-AT usable to gather and refine/categorize behavior data may alleviate some of the privacy concerns users might have. For example, by mining data and synthesizing raw data into more meaningful/useful forms within the W-AT (as opposed to using an external server), sensitive or personal information can be developed and later used for targeted advertising without exposing this information to the rest of the W-AT's communication network.
  • In various embodiments, particular aspects of a user's profile may control portions of the user's W-AT. For example, a user profile generation agent may utilize any retrieved W-AT information to tailor information content in a manner best suited for the W-AT, including the choice of menu layout, such as linear, hierarchical, animated, popup and softkeys.
  • As mentioned above, while most profile generation rules can be interpreted by the W-AT's embedded user profile generation agent, there might be some rules that require large database lookups, e.g., government census data. Since memory on the W-AT may be too limited to accommodate large databases, it may be possible to further refine the already synthesized user behavior and demographic data by offloading the appropriate refinement tasks to a specially configured server at the W-AP side of the M-TCM-PS network. For the present disclosure, any such external server capable of assisting in user profile generation may be referred to as a “profile attribute processor.” Additional discussion of profile attribute processors is provided below with respect to FIG. 4.
  • FIG. 3 is a schematic block diagram of the previously presented user profile generation agent 210 shown in the context of interacting with other devices 312 and 280. Various capabilities of the user profile generation agent 210 (in addition to those discussed above) are provided in part below.
  • One of the features of a mobile phone is that it can be carried by a user wherever he/she goes. Utilizing the GPS capabilities of a W-AT, the W-AT can determine where the user is periodically or a-periodically spending some or most of his/her time. As there is often demographic data associated with locations, the use of GPS information and demographic data associated with locations that the user frequents may allow the development of at least some portions of a demographic profile associated with the user. Typical demographic profile elements associated with the user's profile using the location information may include, but are not limited to:
  • Location ZIP code
  • Gender
  • Median age for the frequented location
  • Age distribution and associated probability
  • Mean travel time to work
  • Household income or household income range
  • Household size
  • Family income or family income range
  • Family size
  • Marital status
  • Probability of owning a house
  • Probability of renting a house
  • Life-stage group/classification
  • Note that multiple demographic user profiles can be maintained at the W-AT for the user. For example, an M-TCM Enabled Client might be configured by the network to maintain two demographic profiles for the user—one for his “home” location (most frequented location between, say, 21:00-06:00) and one for his “work” location (most frequented location between, say 09:00-17:00).
  • In addition to general demographics, a user profile may be further developed using any of a W-AT's numerous applications. Which applications, e.g., games, a user tends to spend most of his time with or how he interacts with the various applications on the phone may provide an opportunity to build a profile for the user based on his behavior and preferences. Most of the data mining and user behavior profile determination of this sort can be done on the W-AT itself, being driven by user profile inference rules fed to the user profile generation agent 210. Typical behavioral profile elements associated with a user may include, but are not limited to, the following:
  • Application ID and time spent in the application
  • Interest categorization
  • Favorite keywords
  • Favorite websites
  • Advertisements of interest
  • Music album
  • Games of interest
  • Many profile elements (including demographics) can be inferred from behavior mined by adding hooks to observe application behavior through a native user interface application on a W-AT. It is through such applications that the user may launch other applications. Applications of interest to the user and time spent in these applications can be inferred by monitoring when the user launches and exits a particular application.
  • Rules fed to the user profile generation agent 210 can associate interest categories for a user based on the user's interactions with applications. Interest categories can also be assigned to the user profile using server assisted collaborative filtering on the behavior data collected at the W-AT.
  • Rules that may get downloaded to the user profile generation agent 210 may allow a server to control the functioning of the user profile generation agent 210 in a dynamic fashion. By mining raw data on the incumbent W-AT and synthesizing it into more meaningful information (profile attributes), particular sensitive user behavior information can be transformed into advertisement behavior categories and user profile elements versus maintaining data in raw form.
  • An exemplary W-AT can keep track of the messages of interest to the user and the keywords associated with such messages. For example, multiple clicks on the same advertisement may indicate to a user profile agent an interest level associated with the associated keywords and advertisement. On the same lines, games and music of interest to the user can be maintained at the W-AT. Server-assisted mode can also be used to associate user interest categories with the user's profile based on the user's music and game play-lists.
  • As a user profile is developed and maintained, such a profile can take a variety of forms, e.g., synthesized profile attributes and elements.
  • Note that some or all data attributes and elements in a user profile may have some confidence level associated with them. That is, because certain elements and attributes are based upon inferences and rules, their results may not be certain and have “fuzziness” associated with them. This fuzziness may be expressed as a confidence level associated with a user profile attribute and element.
  • By way of example, noting that a user is sending more that five-hundred SMS messages per month, the profile generator might say that the user is likely to be in the age group from 15-24 with a confidence level of 60%. That means that if 100 users sending more than five-hundred SMS messages per month were to be polled for their age, about 60 of them are likely to fall within the age group of 15-24.
  • Similarly, when a demographic profile is inferred for a user based on his/her home location, there may be a confidence level associated with the profile attributes. The confidence level here may indicate the number of times the profile attribute is expected to be accurate in a sample of one-hundred users with the same home location.
  • The exemplary user profile generation agent 210 can also be fed rules to combine confidence levels on the same profile attribute from multiple sources to come up with a unified confidence level for the attribute. For example, if the SMS usage rate indicates that the user is within the age group of 15-24 years with a 60% confidence level and demographic profile for the home location indicates that the user is in age group of 15-24 years with a 20% confidence level, then these two items can be combined with fuzzy logic rules to come up with a unified confidence level for the user lying in the same age group.
  • In contrast, if a user enters his interest preferences into the client, then such values might be given a confidence level of close to 100% since they are coming directly from the user. Similarly if the carrier specifies any user profile attributes/elements based on the user data it has (billing data or optional profile data collected from the user during service sign-up), then that too will have a higher confidence level associated with it.
  • As more user behavior data is collected on a W-AT and inferences made based on that, subsequent confidence level, in the profile attribute and element values, is expected to increase.
  • FIG. 4 is a schematic block diagram for a profile attribute processor 270 handling a request by a W-AT for profile attribute processing. As discussed above, while a W-AT may be able to handle most processing, there may be cases where huge database lookups are required to determine portions of a behavior or demographic profile. An example of such cases includes instances where census databases, which may require gigabytes of storage, are useful. Accordingly, a profile attribute processor (or other assisting server) may be used to process user information to provide more refined forms of user profile information.
  • Before a request is received by a profile attribute processor 270, synthesized profile attributes may be gathered at the relevant W-AT, and sent to the profile attribute processor 270 noting that the use of synthesized profile attributes can result in better use of bandwidth. Some of the user profile attributes, which require data-intensive lookups, can be processed by the profile attribute processor 270 optionally by anonymously querying techniques to protect user identities. The profile attribute processor 270 may further refine any received attributes, and provide the refined data to the appropriate W-AT in what may be referred to as a set of refined user profile attributes.
  • When activated by a request from a W-AT, the profile attribute processor 270 may process various types of specific and non-specific synthesized data regarding a user's behavior and demographics (e.g., profile attributes) and respond with the appropriate refined profile information. In order to maintain user privacy, some form of data scrambling, e.g., a hashing function and a number of other tools may be employed via a device, such as the one-way hash function generator 810 of FIG. 8. In operation, it is possible to use a hash function at a W-AT to hide the user's identity from the rest of the M-TCM-PS network.
  • In various operations, a hashing function employed in a W-AT can generate a predictable and unique, but anonymous, value associated with a particular user. Such an approach can enable the W-AT to query external servers without compromising on the privacy of the user. In various embodiments, a hashing function may be based on a primary identifier of the W-AT, e.g. a serial number associated with the W-AT, as well as a random value, a pseudo-random value, and a time-based value. Further, the hashing function may be calculated to provide a low probability of collision with other generated values.
  • The W-AT may use the same random number for subsequent queries to allow external servers to associate multiple queries from the same client. The use of the random number can help to prevent external servers (or unauthorized agents) from doing a reverse lookup on a subscriber base to determine a user's identity.
  • Once a hashed value is generated, the hashed value may be used as an alternate user identifier for the W-AT and provided, along with geographic information or some or items of information from a user profile, and provided to a remote apparatus.
  • Subsequently, one or more targeted content messages can be received from the remote apparatus based on the alternate user identifier and first advertisement-related information to the remote apparatus and/or other information capable of supplementing a user profile. Such information can be incorporated into the user profile of the W-AT.
  • In order to further maintain user privacy, a proxy server at the wireless access point (W-AP) side (see, e.g., FIG. 1) may be used. FIG. 9 depicts a particular communication scheme employing a proxy server for securely communicating in a mobile advertising-enabled network. As shown in FIG. 9, a W-AT 910 (the “M-TCM-Enabled Client”) can send a request (or other message, such as a report or reply) related to a number of services, such as for refinement of user profile information or a request for advertising content, to a wireless application protocol (WAP) proxy 920. The WAP proxy 920, in turn, can forward the request to a secure proxy server 930, which may then create a transaction ID, change out the header to remove the W-AT's identification information in favor of the transaction ID, and forward the request to a mobile message delivery server 940 while creating a look-up table containing that information, e.g., the W-AT's IP address, useful to relay a reply.
  • Once the mobile message delivery server 940 receives and replies to the request, the proxy server 930 may use the appropriate transaction ID to forward the mobile message delivery server's reply. Later, the proxy server 930 may delete the look up table entry.
  • Note that the scheme depicted in FIG. 9 can be employed to disallow the mobile message delivery server 940 access to the user's W-AT IP address, which in turn has a number of benefits, such as allowing the delivery of targeted content, e.g., targeted ads, without compromising user identity.
  • In order to alleviate concerns of users that their location is possibly being tracked in real-time by their W-ATs, such W-ATs may elect not to query the server for refinement of location data in real-time. Note that such queries can be sent anonymously and sparsely over an extended period of time (e.g., once a month). A typical schedule could be, for example, to collect location information every 5 minutes for 72 hours. The most frequented location during this time frame or during specific time frames can be used to query the demographic profile of the user from the server at a randomly selected time between 30 and 40 days or by some other schedule specified by a the system operator.
  • The above case is an example of a hybrid approach using both the rule driven operation of the user profile generation agent along with the server-assisted mode to generate profile elements for the user while maintaining the user's privacy.
  • FIG. 5 is a schematic block diagram shown depicting an exemplary operation of such a hybrid approach using a user profile generation agent 210 having a user behavior synthesizer 522 and a profile element refiner 524. While the majority of functionality of the various devices of FIG. 5 has already been discussed above, further functionality will be described below with respect to the following flowcharts.
  • FIG. 6 is a flowchart outlining an exemplary operation for generating and using a user profile. The operation starts in step 602 as a number of user profile inference rules (basic and/or qualified rules) can be received (and subsequently stored) by a W-AT from a system operator or other party.
  • As discussed above, basic rules may include pre-scheduled events, e.g., performing a query of the user at a specific time. Similarly, a respective qualified rule might require the same query to be preceded by a condition and/or event, such as physical status information or operational status information.
  • Next, in step 604, the received rules can be used to collect raw data, and in step 606 the raw data may be processed/synthesized into user profile elements or attributes noting that while all such processing/synthesizing may occur on board the W-AT, some refinement may occur using external devices, such as the profile attribute processors discussed above. That is, as discussed above raw data and/or synthesized data may be incorporated to form a user profile for the W-AT's user. For example, a rule relating to monitoring SMS messages may be used to change a dynamic property of a user profile when applied to collect raw data and synthesize profile attributes/elements regarding SMS messages. Static data, e.g., a user's birth date, may be likewise collected using a rule to query the user, and then applied as an element in a user profile.
  • Then, in step 608, confidence levels for user profile data can be determined. Note that confidence levels can have a variety of forms, such as a range of numbers, variance statistic, or distribution profile.
  • In step 610, various received rules plus raw data and synthesized data relating to various user profile elements and attributes, which may form all of a user profile, may be used to receive TCMs. That is, as discussed above, in various embodiments a used/usable rule on a W-AT may be used to generate a user profile—along with collected raw data and synthesized data—to provide any number of static or dynamic properties of the user profile, and such information may be used to receive content, such as advertisements, sports scores, weather reports and news directed to subjects of likely interest.
  • Note that in various embodiments where user profile data can have confidence levels associated with them, rules may be applied to the confidence levels and targeted content messages may be received and displayed based on such confidence information.
  • Continuing, control of the operation may jump back to step 602 where new/more rules may be received and used to collect data and modify the user's profile.
  • Note that, as referenced above rules may be used based on physical configuration of an W-AT so as to utilize W-AT information to tailor content display in a manner suited for the W-AT to create suitable displays, such as menu layouts having linear, hierarchical, animated, popup and/or softkey attributes.
  • FIG. 7 is a flowchart outlining another exemplary operation for generating and using a user profile. The operation starts in step 702 as a number of user profile inference rules are received by a W-AT from a system operator or other party. Next, in step 704, the received rules can be used to collect raw data, and in step 706 the raw data may be processed/synthesized into user profile elements or attributes using onboard resources. Again note that any item of user profile information may have confidence level information processed and synthesized along with the basic data.
  • Continuing to step 710, a determination may be made as to whether further information or processing is required that may not be practical on a W-AT. For example, assuming that a W-AT has accrued a series of locations for which the W-AT regularly has visited using a GPS, a software agent on the W-AT using one or more rules may determine the need to query a large external database, such as a geographic information service or a national census database on a remote server, to determine a likely ethnicity (or other demographics) of the user. If further information or processing is required, control continues to step 712; otherwise, control of the operation may jump to step 720 where profile attributes are used to generate/modify the user's profile.
  • For instances where further information or processing is required, a request may be made of an external device (step 712), such as by the profile attribute processor discussed above (optionally using hashing functions and/or proxy servers) to protect user information.
  • Next, in step 714, the external device can perform any number of refinement steps, such as query large databases, to produce refined user profile attributes. Then, in step 718, refined user profile attributes may then be provided to the appropriate W-AT, where (in step 720) they may be used to generate, modify or otherwise incorporated in a user profile. Note that when confidence levels are available for processing, unified confidence levels may be determined based on individual confidence levels. Control of the operation may then jump back to the step 702 where new/more rules may be received and used to collect data and modify the user's profile.
  • Jumping forward to FIG. 11, a first communication protocol for TCMs distribution in a M-TCM-enabled network is depicted. This exemplary figure illustrates a possible data flow during a multicast “push” of messages from a message distribution infrastructure. Note that the User Profile Generation Agent (in the Mobile Device (W-AT) 100 of FIG. 10) can retrieve messages, then select one or more of the received the messages by internal filtering.
  • In operation, a network system operator 280 (and/or a third party) may provide profile attribute processing rules to the profile attribute processor 270. The profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 and provide an appropriate response through modules on the W-AT 100.
  • Additionally, multicast or broadcast advertisements may be received by the W-AT 100 by a multicast/broadcast distribution server 1110. In this configuration, the W-AT 100 (or other Mobile Device) can be able to receive all messages and determine which messages are to be stored and presented to the user in accordance with the user profile generated at the W-AT 100 and the filter rules also received from the multicast/broadcast distribution server 1110 of FIG. 11.
  • FIG. 12 depicts a second communication protocol for message distribution in a M-TCM-enabled network. As with the example of FIG. 11, a network system operator 280 (and/or a third party) may provide profile attribute processing rules to the profile attribute processor 270, and the profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 to provide an appropriate response through modules on the W-AT 100.
  • However, in this embodiment unicast messages may be requested by the W-AT 100 from the unicast message distribution server 1210. The W-AT 100 may be able to receive all messages over a unicast communication link and determine which messages are to be stored and presented to the user in accordance with the user profile generated at the W-AT 100 and the filter rules also received from the unicast message distribution server 1210.
  • FIG. 13 depicts another communication protocol for message distribution in a M-TCM-enabled network. Again, as with the previous examples, a network system operator 280 (and/or a third party) may provide profile attribute processing rules to the profile attribute processor 270, and the profile attribute processor 270 may also receive a profile attribute process request from modules on the W-AT 100 to provide an appropriate response through modules on the W-AT 100.
  • However, in this embodiment, the unicast messages distribution server 1310 may receive user profile information provided by the W-AT 100, process the received user profile information, and then provide the appropriate TCMs to the W-AT 100.
  • FIG. 14 depicts yet another communication protocol for message distribution in a M-TCM-enabled network. This example may work much the same as the previous examples with respect to the profile attribute processor side of operation. However, message retrieval over the unicast communication link is substantially different.
  • In operation, the W-AT 100 may send a request for messages where after the W-AT 100 can receive a set of metadata representative of the various messages available in the message distribution server 1410. The W-AT 100 may then select a number of messages based on the metadata and on the filtering rules within the W-AT 100, and provide the selection information to the message distribution server 1410. Accordingly, the selected messages can then be provided to the W-AT 100 and presented to the user in accordance with the user profile rules.
  • The above approach keeps the user profile local on the W-AT while using optimal network bandwidth when delivering advertisements to the W-AT over the unicast communication link.
  • FIG. 15 depicts a timeline for a first communication protocol for downloading message content according to “contact windows” (see exemplary windows 1510-1516) approach. This may be used to permit downloading of TCMs at an opportune time without burdening other functions of the W-AT. In various embodiments, the W-AT may be able to adjust its sleep mode, if engaged, to the contact windows. In operation, a W-AT can be put into a sleep mode to optimize energy consumption on the platform during content message delivery. It is possible that in a sleep mode, the W-AT may be engaged in other useful operations. That is, a W-AT may be able to be put into a sleep mode while various timing circuitry (not shown) may be programmed or otherwise manipulated to respond to the sleep mode and a contact window or other schedule by disengaging the sleep mode before and/or during the contact window, and possibly re-engaging sleep mode subsequent to receiving TCMs or at the end of the relative contact window.
  • FIG. 16 depicts an alternate timeline for a first communication protocol for downloading targeted-content-message information according to a defined time schedule. Referring to exemplary windows 1610-1620, this approach may be used to permit downloading of TCMs at an opportune time without burdening other functions of the W-AT. The defined time schedule permits the W-AT to remain in sleep mode except during the defined time schedule. Again, various timing/clock circuitry may be employed to engage and disengage a W-AT to/from sleep mode. Additionally, it is possible that when the W-AT wakes up to receive TCM information, it can receive targeting meta-data and reception times for future TCMs, which can then be used to determine whether to receive a future TCM based on the user profile and the targeting meta-data, and to schedule an appropriate wakeup time prior to the reception time for a future TCM delivery.
  • FIG. 17 illustrates some of the cache modeling scenarios based on exemplary information streams 1702, 1722 and 1732. As shown in FIG. 17, the cache modeling scenarios are based on various listed classifications. Note that a message cache can be a store house for the messages at a M-TCM-enabled client. Messages may be cached locally to enable immediate play-out of the messages when there is an opportunity to serve a TCM.
  • The actual storage space in a cache may be divided into multiple categories based on different types of classifications. These classifications can be defined by System Operator using filter rules. The amount of space allocated to each category within a classification may be fixed or may be dynamic based on some defined criterion, again defined through a filter rule by the System Operator. Some categories of interest include:
  • Default messages (1710, 1720 and 1730): These may be thought of as “fallback” messages that can be marked such by the System Operator. They are shown when no other message satisfying the message type requested by a device application is available for display.
  • Default messages can be candidates for a cache as long as there is at least one message delivery-capable application subscribed with the respective client message delivery engine with the same message type as the candidate default message. In addition, default messages may be made to satisfy the minimum gating criteria of device and application capability compliance.
  • Based on the value calculated for a default message, a previously stored default message may be replaced by a new one as long as the “normalized” value of the new message is greater than the value of previously stored default messages under the same message type.
  • The maximum number of default messages allowed on a client for each message type may be defined by the system operator through a filtering rule. In various embodiments there may be a fixed number of messages or message memory, or message number and/or memory may be determined dynamically based on a particular message capable application, usage, etc. Typically, in a number of embodiments, the maximum number of default message allowed for each message type is 1.
  • Messages that are marked as default messages primarily serve two purposes: (1) they serve as “fallback” messages in each category and help the system to take advantage of each opportunity to present a message to a user; and (2) they allow a System Operator to offer “tiered pricing” and (optionally) charge more for default messages.
  • Targeted messages (1712, 1722, 1724 and 1738) and non-targeted messages (1714, 1726 and 1740): One classification scheme would be to divide a cache store into space for targeted and non-targeted messages. The targeted message cache space can be used to store only messages for which the user profile for the user of the M-TCM-enabled client matches the target user profile contained in the relevant metadata.
  • For messages where the target user profile does not match the device user's profile, as long as the messages are not marked as “targeted-display-only”, such messages can be candidates to be placed in the non-targeted message cache space. Having non-targeted messages for display can allow a system to gauge change in user interest with time, and modify the respective user profile and cache accordingly.
  • Impression-based messages (1722) and action-based messages (1724): Another classification would be to divide the targeted or non-targeted portion of a cache space based on whether a message is an impression type of TCM delivery campaign or the message is one which solicits a user action to gauge user interest. Partition sizes or ratios for such a sub-classification might be defined by a System Operator or might be dynamically decided by the capabilities and usage rate of message delivery capable applications onboard a respective W-AT.
  • User Interest Based classification (1732-1736): A sub-classification under the targeted message classification could be based on a user interest classification. For example, most of a particular cache space within a targeted message section of a cache could be reserved for the top three user interest categories while any remaining cache resources may be devoted to other categories matching a user's profile. Again the actual ratios or number of interest based categories within such a classification may be defined by a System Operator and/or may be dynamic based on the relative click-through rates for ads (or other messages) within each interest category.
  • FIG. 18 is an illustration of a message filtering process context. One purpose of a message filtering process within a mobile targeted content message delivery system can be to decide which of any available new messages entering the system should be cached at a particular mobile client.
  • In operation, a filtering process 1810 may use a number of inputs, such as a user profile of the user maintained within the system, the device and application capabilities on the mobile client, the current cache state on the mobile client and filtering rules defined by a System Operator or some 3rd party 280 to determine which new messages to cache. Upon processing each received messages, a number of selected messages may be determined and stored in cache 1820 along with the respective metadata.
  • FIG. 19 is a data flow diagram for a TCM filtering process within a TCM delivery system in the context of various exemplary functional components. As shown in FIG. 19, message filtering may be a multi-step process. New messages entering a filtering agent 220 from sales interface 164 may first pass through a gating sub-process 220-1 that may determine which received messages are possible candidates for an message cache. Note that the exemplary gating sub-process 220-1 may use device and capabilities information from an appropriate storage device 1910 associated with the mobile client, as well as filter rules by the System Operator or some 3rd party 280 and user profile information from an appropriate agent 210 or storage device.
  • Continuing, the possible candidates of the gating sub-process 220-1 may then be processed by a selection sub-process 220-2 that may determine which candidate messages may be replaced in case of message space contention. Note that the selection sub-process 220-2 may use filter rules by the System Operator or some 3rd party 280, user profile information from an appropriate agent 210 or storage device and feedback cache information from a cache manager 122.
  • FIG. 20 shows an exemplary data flow within the gating process of FIG. 19. One purpose of this process is to ensure that targeted content messages, such as targeted ads, meet certain requirements before they are forwarded to a selection process. The present process starts in step 2002 where messages and respective metadata may be provided from a sales interface 164 or other device. Next, in step 2004, a determination is made as to whether the messages of step 2002 are within the capabilities of the mobile client. That is, messages should be such that they can be supported by the physical plant of a mobile device. For example, if a message is meant only for the secondary device screen but the mobile device at issue does not have one, the message is not suitable. Should the message match device capabilities, control continues to step 2006; otherwise, control jumps to step 2020 where the message is rejected for use.
  • In step 2006, a determination is made as to whether the messages of step 2002 are within the applications capabilities of the mobile client. That is, messages should be such that they can be supported by the various software/firmware registered for use with the mobile device. For example, if a message includes a video of 15 seconds but there is no CODEC facility within any of the device applications to show such a video, the message not suitable. Should the message match applications capabilities, control continues to step 2008; otherwise, control jumps to step 2020 where the message is rejected for use.
  • In step 2008, a determination is made as to whether the messages of step 2002 pass a system operator specified gating criteria match within the applications capabilities of the mobile client. For example, if a message is suitable for adult audiences only, such message would be likely best filtered out for any user that is identified as a minor. Should the message match the specified system operator specified gating criteria, control continues to step 2010; otherwise, control jumps to step 2020 where the message is rejected for use.
  • In step 2010, a determination is made as to whether the messages of step 2002 pass a sampling criteria match. For example, if a particular advertisement is slated to be provided to only 30% of a demographic, a random number generator (RNG) having a range of 1 to 100 and seeded with its own ESN and a server specified seed may qualify the advertisement if the resultant random number is less than 30%. If the ad/message passes the sampling criteria, control continues to step 2030 where message selection may be performed; otherwise, control jumps to step 2020 where the message is rejected for use.
  • FIG. 21 is a flowchart depicting a random sampling scheme, which is presented for situations where an operator might want to divide the users into mutually exclusive sets and target different messages to each set. For example, the operator might be under contractual obligation not to show any Pepsi ad and any Coke ad to the same user. Accordingly, the operator might want to target the Pepsi ad to 50% of the subscriber base and Coke ad to the remaining 50% of the subscriber base, making sure that both ads are not shown to the same user.
  • The process starts in step 2102 where a random number generator seed and ESN (electronic serial number) are provided to a mobile client/W-AT. Next, in step 2104, a random number generation process is performed to generate a random number between 1 and 100—or between any other range of numbers. Control continues to step 2110.
  • In step 2110, a determination is made as to whether a match is made between the random number of step 2104 and a defined range, e.g., 1 to 50 or 51 to 100 out of a total range of 1 to 100. If a match is made, then control jumps to step 2112 where the message at issue is accepted, or if there are competing ads as with the Coke/Pepsi example above, the first of two messages is accepted; otherwise, control jumps to step 2114 where the message at issue is rejected, or if there are competing ads as with the Coke/Pepsi example above, the first of two ads is rejected while the second ad is accepted.
  • Continuing to FIG. 22, it should be appreciated that mutually exclusive message targeting within the subscriber base can be done using a one-way function like a hashing scheme on some unique ID, such as a user ID or device ID. In operation, an operator can specify different target user segments based on the result of the hashing calculations. Such a sampling might be done to target a section of users defined by a range of the hash values for their respective ESNs.
  • The process starts in step 2202 where unique ID is provided to a mobile client/W-AT. Next, in step 2204, a one-way hashing process may be performed to generate a value between any range of numbers. Control continues to step 2210.
  • In step 2210, a determination is made as to whether a match is made between the hashed value of step 2204 and a defined range. If a match is made, then control jumps to step 2212 where the message at issue is accepted, or if there are competing ads as with the Coke/Pepsi example above, the first of two messages is accepted; otherwise, control jumps to step 2214 where the message at issue is rejected, or if there are competing ads as with the Coke/Pepsi example above, the first of two ads is rejected while the second ad is accepted.
  • Note that when a client's hash value does not fall in a sampling range specified by the system operator, the message may be rejected; otherwise, message processing may continue to the next gating criteria or selection phase. Also note that an operator might also choose a hybrid approach to sampling users for a particular ad/message distribution campaign by targeting randomly within mutually exclusive sets. As an example, a particular ad campaign might be targeted to a random 20% of the subscriber base that did not get a first ad. This would be achieved by first using a one-way function based sampling to come up with a mutually exclusive set and then to target randomly within the mutually exclusive set.
  • Continuing, FIG. 23 shows an exemplary data flow within a message selection process 2300. A purpose of the selection process can be to select messages from a pool of messages that are forwarded to a mobile client/W-AT by a gating process, and store the selected messages in a memory, such as a special client ad/message cache. In case of message space contention, the selection process 2300 may also be employed to select previously cached-messages that need to be replaced from the cache.
  • Message selection may come into play when there is contention over cache space, i.e., there is not enough space in the cache to accommodate all the new messages and the previously cached messages. Message selection may be a multi-step process, and because a cache may be divided into among different categories (dynamically or statically), contention and selection may happen in each message category.
  • In operation, a message selector 2310 may receive new messages from a gating device 220 or other instrument performing a gating process, as well as a number of message filter rules from a system operator or 3rd party 280. The message selector 2310 may then apply the various filter rules to each new message to determine whether each new message passes some basic criteria, such as whether the new message is age or gender appropriate. Should a particular message not comply with the filter rules, it may be categorized as a rejected new message and discarded.
  • Messages not discarded under the filter rules may be further processed by the message selector 2310 to derive a “target user profile” for each received message to a match indicator calculator 2320, which may then compare the target user profile(s) to a user profile provided by a user profile generation agent 210 or some other device storing information on a user. In turn, the match indicator calculator 2320 may perform a match between each target user profile and the user profile associated with the user or mobile client/W-AT, and provide a match indication “score” to the message selector 2310 that quantizes how well a particular incoming/new message is compatible with the user profile.
  • If the match indication “score” ranks well enough, the respective message can be further considered; otherwise, it may become a rejected new message.
  • Messages that are further processed by the message selector 2310 may provide the match indication “score”, along with other message value attributes, such as the message size, duration, memory and display requirements and so on, to a message value calculator 2330, which in turn can provide a “message value” for such messages back to the message selector 2310.
  • Continuing, the message selector 2310 may receive information from a cache manager 122 about the state of an available cache (or portion of a cache devoted to a particular message category), along with cache hit/miss information and the message value for each message in the cache (or relevant portion). Depending on the hit/miss information for a particular message, a message value for a given message may optionally be adjusted.
  • The message selector 2310 may then determine whether a newly received message is to replace one or more existing messages in the cache based on relative message values, and any newly selected messages may then be sent to the cache manager 122 along with the respective message IDs and respective message values, and any replaced messages may be discarded/rejected for further use.
  • FIGS. 24A and 24B depict a flowchart outlining a message selection process for one or more new messages received at a mobile device, such as a W-AT. The exemplary process flowchart shows the high level flow of actions that take place during message selection to determine which new messages to add to a cache and which previously cached message are to be replaced/discarded.
  • The process starts in step 2400 where a determination is made for a first new message whether the size of the message is less than or equal to some maximum message size for a particular cache memory and (optionally) for a particular message category, e.g., movie trailers, baseball highlights, weather reports and clothing sales. If the new message size conforms with the cache memory requirements of step 2400, control jumps to step 2402; otherwise, control continues to step 2408.
  • In step 2402, the new message is placed in cache memory. Next, in step 2404, a message value for the new message is calculated, and a “priority queue” for various messages in the cache—and optionally for a message category of the cache—is updated with the message value of the new message. Then, in step 2406, the available cache size is updated (again with an optional updating for the particular message category) based on the new message. Note that such message values may used to maintain a priority queue for each category within the cache. Periodically (on a pre-defined schedule), an engine may recalculate the various message values in the cache and re-adjusts the priority queues based on the new values. Such periodic updates to the value based priority queues may result in lesser time being spent when new messages are being considered as cache replacement candidates, since the values in the queue are a good approximation of what the current values would be. The process then continues to step 2430 (discussed below).
  • In step 2408, a message value for the new message is calculated. Next, in step 2410, a determination is made as to whether the new message is to be a default message. If the new message is to be a default message, control jumps to step 2412; otherwise, control continues to step 2420.
  • In step 2412, a determination is made as to whether the value of the new message is greater than the value of a default message of the same type already existing in the cache. New messages marked as default messages and having value greater than one or more of already stored messages can be given priority. The additional size (if they are greater in size than the message(s) to be replaced—of if the new message(s) are catering to a new message type for which there are no previous default messages of such category can be calculated since these messages can be accommodated in the cache. Old default messages that are of lower value than the new ones may be marked for replacement. Each message type may typically have a fixed number (typically 1) of default candidates. If the new message value is greater, control jumps to step 2414; otherwise, control continues to step 2422.
  • In step 2414, the total size for all default messages is updated, and in step 2424, existing cached message(s) to be replaced are marked for deletion while the new message is marked for addition to the cache. Note that based on how the cache is divided or allocated to the various categories of messages, new space allocations can be calculated for each category. Control continues to step 2430.
  • In step 2422, the new message is marked for deletion, and control continues to step 2430.
  • In step 2420, a new message value for each new non-default message may be added to a respective priority queue for various message categories, and control continues to step 2430.
  • In step 2430, a determination is made as to whether there are any more message candidates to be considered. If more message candidates are available, control jumps back to step 2440 where a next message is selected for consideration, and then back up to step 2400 where the next message is made available for processing; otherwise, control continues to step 2450.
  • In step 2450, the available size for all new non-default messages can be determined based on the difference between the total cache size and the amount of memory taken up by default messages. Next, in step 2452, the available memory for each category of messages can be calculated based on some “category ratio”, parametric equation, or by some other set of rules and/or equations. Control continues to step 2454.
  • In step 2454, various messages having the lowest associated value can be marked for deletion for each message category in order to conform with the available memory for each respective category of messages. Next, in step 2456, those messages marked for deletion can be removed from the cache, and their respective value entries may also be removed from the respective priority queue. Then, in step 2458, those new messages marked for deletion can be requested, and their respective value entries may also be removed from the respective priority queue. Control continues to step 2460.
  • In step 2460, those new messages not marked for deletion can be added to the cache, and their respective value entries may be retained in the respective priority queue. Control continues to step 2470 where the process stops.
  • With respect to determining message values and message value attributes, the following may be considered:
  • Message Value Attributes: Calculating a value for a message may consider a number of attributes, based on the type of message. While a number of these attributes may be defined by a server to maintain centralized control over a message delivery scheme, e.g., an advertising campaign, across a message-enabled communication system, some of the attributes that go into message value calculation may be determined on the mobile client/W-AT based on how the respective user interacts with the message.
  • Server Based Value Attributes:
  • Revenue indicator (RI): A value in the range of 1 to N (e.g., 100) indicative of the revenue earned per serving/clicking of the message/ad. Higher values indicate higher revenue.
  • Priority indicator (PI): A value in the range of 1 to M (e.g., 10) indicative of the priority level the system operator has scheduled for the message based on some measure of performance, e.g., the effectiveness of an advertiser's ad campaign, over a mobile message delivery system. This number may be increased by an operator to increase the priority of a given message delivery campaign.
  • Start and end time of message delivery campaign (TSTART and TEND): UTC time for the message delivery campaign viewing start time and message campaign viewing end time. After the message campaign viewing end time, the message can expire and may be no longer shown within the mobile message delivery system. It also may be removed from the respective cache at this time.
  • Overall system click-through rate (CTR): This is an optional attribute included by a server to indicate the overall click through rate of a message campaign across all clients with the target user profile that were served the message within the mobile message delivery system. CTR may be applicable only for user-action or click based messages/ads. The CTR also may have a confidence level (CTRCONFIDENCE) associated with it that is indicative of the accuracy of the CTR. If CTRCONFIDENCE is below a certain threshold, a random CTR in the range of 1 to P (e.g., 100) may be generated to be alternatively used in the respective value calculation. This can allow the system to test how a particular new message/ad campaign would do with a subscriber segment.
  • Target message serve count (MAXSERVE): This is an attribute that defines the maximum number of times the same message can be shown to the same user.
  • Target user actions count (MAXUSERACTION): This is an attribute that defines the maximum number of times a user acts upon a served message after which the message can be expired from the respective cache. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Max message serve count per day (DAILYMAXSERVE): This is an attribute that defines the maximum number of times the same message can be shown to the same user within a single day.
  • Max user action count per day (DAILYMAXUSER ACTION): This is an attribute that defines the maximum number of times a user acts upon a served message after which the message is not served to the user for that day. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Client Based Value Attributes:
  • Cumulative message served count (CUMSERVE): The number of times an existing message has already been served to a particular user.
  • Cumulative user action count (CUMUSER ACTION): The number of times an existing message has invoked a user action. Together with the cumulative message served count, the cumulative user action count can be used to calculate a local client click-through rate (LCTR) for the message. In various embodiments, this attribute may be applicable only for user-action or click-based messages/ads.
  • Cumulative message served count per day (DAILYCUMSERVE): The number of times an existing message has already been served to the user in a given day. This value may be reset to 0 at the beginning of each 24 hour period.
  • Cumulative user action count per day (DAILYCUMUSER ACTION): The number of times an existing message has invoked a user action in a given day. This value can be reset to 0 at the beginning of each 24 hour period. In various embodiments, this attribute may be applicable only for user-action or click-based ads.
  • User Profile match indicator (MI): This number, typically between 1 and 100, may be indicative of how well the target user profile matches the user profile of the user of the mobile message distribution enabled client.
  • Cache miss state match indicator (FLAGCACHE MISS MI). There may be cases where applications ask for messages from the cache manager but none of the messages in the cache match the application gating criteria. Such instances can be recorded by the cache manager. This attribute determines whether the new message matches the most recent recorded cache misses. It can be a logical “1” if it matches one of the recent cache misses and a logical “0” otherwise. The flag can be reset once the message is accessed by an application from the cache. If the new message is selected for cache entry, the cache miss entry can be removed from the list of recorded cache misses.
  • Playback Probability Indicator (PPI): This number, between 0 to P (e.g., 100), can be indicative of the playback probability of the message, based on the number applications subscribed with the filtering agent capable of playing back the particular message type, the relative usage of the applications by the device user, and so on.
  • Since some of the value attributes are applicable for only certain kind of messages, the value calculation can be different for different categories of messages. A separate priority queue can be maintained for each category based on the values calculated using the formula for that particular category.
  • Message Value Calculation Formulae: The filter rules from the System Operator may determine the value calculation formula for each category and any weights that go into the calculation. An exemplary generic representation of a formula used to calculate a message value (V) in each category is:

  • V=(Πa=1 to mMULT_ATTRa*(Σb=1 to nADD_ATTRb/MAX_ADD_ATTRb *WT b))/

  • b=1 to n WT b*SizeAD)
  • with the normalized message value being:

  • Normalized V=Σ i=k to N V*(MAXSERVEi−CUMSERVEi)*f(τ)
  • where MULT_ATTRa is the ath multiplicative value attribute, ADD_ATTRb is the bth additive value attribute, MAX_ADD_ATTRb is the max value for the bth additive value attribute, WTb is the weight assigned to the bth additive attribute in the formula, τ=tELAPSEDi/TINTERVALi, and f(τ) is a time-based value decay function, TINTERVALi is the ith interval duration during which the message will be shown, tELAPSEDi is the time that has already elapsed in the ith interval, MAXSERVEi is the maximum number of times the same message can be shown to the same user within the ith interval, and CUMSERVEi is the number of times an existing message has already been served to the user within the ith interval.
  • Following are some examples of value calculation formulae for different categories.
  • Value calculation for impression based targeted messages:

  • VAL=(PI/10*[(RI/100*WT RI)+(MI/100*WT MI)+

  • (FLAGCACHE MISS MI *WT CACHE MISS MI)+(PPI/100*WT PPI)])/

  • ((WT RI +WT MI +WT CACHE MISS MI +WT PPI)*SizeMSG)
  • Value calculation for impression based non-targeted messages:

  • VAL=(PI/10*[(RI/100*WT RI)+(FLAGCACHE MISS MI *WT CACHE MISS MI)+

  • (PPI/100*WT PPI)])/((WT RI +WT CACHE MISS MI +WT PPI)*SizeAD)
  • Value calculation for user-action based targeted messages:

  • VAL=(PI/10*[(RI/100*WT RI)+(MI/100*WT MI)+(FLAGCACHE MISS MI*

  • WT CACHE MISS MI)+(PPI/100*WT PPI)+(CTR*WT CTR)+(LCTR*WT LCTR)])/

  • ((WT RI +WT MI +WT CACHE MISS MI +WT CTR +WT LCTR +WT PPI)*SizeMSG)
  • Value calculation for user-action based non-targeted messages:

  • VAL=(PI/10*[(RI/100*WT RI)+(FLAGCACHE MISS MI *WT CACHE MISS MI)+

  • (PPI/100*WTPPI)+(CTR*WTCTR)+(LCTR*WTLCTR)])/

  • (WT RI +WT CACHE MISS MI +WT CTR +WT LCTR +WT PPI)*SizeMSG)
  • where RI is the revenue indicator value on a scale of 1 to 100, PI is the priority indicator value on a scale of 1 to 10, CTR is the click-through rate for the message within the system for the given user profile, LCTR is the click-through rate for the message for the specific client, MI is the match indicator between the target user profile and the user's profile on a scale of 1 to 100, FLAGCACHE MISS MI is the match indicator between the message type and the cache miss state with a value of either 0 or 1, PPI is the message playback probability indicator on a scale of 1 to 100, WTRI is the weight for the revenue indicator in the calculation, WTMI is the weight for the match indicator in the calculation,
    WTCACHE MISS MI is the weight for the cache miss state match flag in the calculation, WTCTR is the weight for the user profile specific system click-through rate in the calculation, WTLCTR is the weight for the client specific click-through rate for the message in the calculation, and WTPPI is the weight for the message playback probability indicator in the value calculation.
  • Examples for f(τ)
  • Linear decay: f(τ)=(1−τ)*u(1−τ)
  • Faster exponential decay bounded by linear decay: f(τ)=(1−τ)e−λτ*u(1−τ) noting that when λ=0 linear decay occurs; when τ=0, f(τ)=1; and when τ=1, f(τ)=0.
  • Slower sigmoid decay bounded by linear decay: f(τ)=(1−τ)[(1+{acute over (α)})/(1+{acute over (α)}eλτ)]*u (1−τ) noting that when λ=0 linear decay occurs; when τ=0, f(τ)=1; and when τ=1, f(τ)=0, and further noting that u(x)=1 when x>0; and u(x)=0 when x<=0. Also, λ and {acute over (α)} are value decay rate constants specified by the system operator based on time
  • Message Match Indicator Calculation: As briefly alluded above, the User Profile Match Indicator (MI) may be a number, and not necessarily between 0 and 100, which is indicative of how well the target user profile matches the user profile of the user of the Mobile Message Delivery Enabled Client and either his past message/advertisement viewing history or some metric of the his message/advertisement preference(s). Though the MI can be described as a scalar numerical quantity, it should be appreciated that one or more alternative “weighting” schemes can be devised, for example, using a polynomial function or vectors, according to design preference. Thus, other values (scalar or non-scalar, single valued or multi-valued, for example) can be assigned without departing from the spirit and scope of this disclosure.
  • For illustrative purposes, several implementations of a advertisement match indication calculation is described, using a scale quantity between 0 and 100, since this is one of the simplest ranges that can be given. Other ranges may used as desired. One such implementation utilizes fuzzy logic which can be used to generate confidence level values for each of the independent target rule groups specified by the advertiser. From these confidence levels, a weighted summation of these confidence levels can be used to arrive at the match indicator value for the advertisement to the user's profile. The following, non-limiting equation, may be used as an example of one type of fuzzy logic,

  • MI=(τb=1 to nCONF_LEVELb *WT b)/(Σb=1 to n WT b)
  • where the overall match indicator for the message to the user's profile (MI) is related to the sum of confidence levels (CONF_LEVEL) times a weight (WT) corresponding to an attribute value (b) divided by the sum of the weight (WT) corresponding to the bth additive attribute.
  • As an example of confidence level calculation, presume an advertiser who desires to target his advertisement(s) towards females, to females who are in the age range of 15-24 and with an income above 40K, or who are in the age range of 25-34 and with an income greater than 70K. Knowing the values of the user profile elements of interest and presuming the associated confidence levels are:
  • User Profile Element Value Confidence
    Female
    50%
    Age: 15-24 40%
    Age: 25-34 35%
    Income: >40K 65%
    Income: >70K 45%
  • The confidence level for the rule groups are: Female=50%
  • For the composite rule group of age 15-24 and with income above 40K, or age 25-34 and with income greater than 70K, a maximum/minimum approach can be used. For example, taking the maximum value of the minimum of the two groupings (e.g., MAX (MIN (40, 65), MIN (35, 45)) results in MAX (40, 35), which is a 40% confidence level for this grouping.
  • The overall MI for the entire rule groups would be the combination of the “female” confidence level 50% and the composite confidence level 40%, factored by the associated WTb and divided by the sum of the associated WTb's. As stated above, other forms of fuzzy logic may be used without departing from the spirit and scope of this invention.
  • While this demonstrates one approach to determining the User Profile Match Indicator value, other approaches such as statistical averaging, curve fitting, regression analysis, and so forth may be used to arrive at a reasoned indication of the match between the advertisement's target profile and the user's profile. Though the above approaches are understood to be primarily scalar approaches, non-scalar approaches using vector representations (e.g., dot-product), artificial neural net topologies, etc. may be used.
  • For example, the confidence levels each attribute for an individual rule group may be represented by an n-dimensional vector. The n-dimensional vector may be a dot-product with other m-dimensional individual groups, if necessary (for example, if the different individual rule groups are separately vectorized), to result in an overall intersection or projection of the advertising rule group confidence. This value can then be scalar manipulated or “dot-product ed” (depending on the projection space) with a mathematical representation of the user's profile, to generate a match indication confidence level.
  • Other match-type algorithms such as a bubble or hierarchal approach may be used. Of course, it should be understood that various forms of these and other approaches may be used, if so desired to arrive at a more precise and/or efficient determination of the advertisement match. Match algorithms may be resident on the mobile message delivery system or on the mobile message delivery enabled client, if so desired. Additionally, depending on a chosen configuration and resources, portions of these algorithms may be parsed between the message delivery system or the message delivery enabled client.
  • FIG. 25 is a flow chart illustrating an exemplary User Profile Match Indicator (MI) process 2500 according to an embodiment of this invention. The exemplary process 2500 embodies any one or more of the algorithms/schemes discussed above. The exemplary process 2500 is initiated at step 2510, and continues to step 2520 whereupon message target parameters, e.g., an advertiser's advertisement target parameters, are compiled or characterized.
  • Next, in step 2530, the exemplary process can proceeds to generating a metric or mathematical representation of the target parameters. In various embodiments, this step may simply entail a conversion of the parameter characteristics into a manageable number, such as a scalar value having a range between 0 to 100. Of course, any range, whether positive and/or negative may be used, depending on design preference. Step 2530 can enable an advertisement's target parameters to be represented by a mathematical expression or value. For example, if an advertiser desires to target all females and is not privy to the female-to-male subscriber ratio, then his request would be converted according to the provider's subscriber population breakdown. That is, presuming a 1:1 female-to-male ratio in the provider's subscriber population, this would be a value of 50% or 0.50. Alternately, if the respective subscriber gender ratio for a particular provider is 1:2, then this would translate to an approximate 33.3% subscriber population, or an approximate value of 0.333.
  • It should be understood that other manipulations may be performed on the target parameters, such as a conversion to a vector or a parameterized expression. Also, depending on the initial format in which that the target parameters are presented, step 2530 may simply consists of forwarding the parameters to the next step with little or no manipulation. That is, target parameters may already be in a form amenable for processing by the subsequent steps and may not necessitate any conversion. Control continues to step 2540.
  • In step 2540, an optional conditioning or transformation of the formulated mathematical expression or metric may take place. For example, depending on the complexity of a message's target parameters and the definition space allocated to the message's target parameters, further processing and manipulation may need to be performed. For example, a correlation between different advertisement target parameters may be performed. For instance, if an advertiser desires a female target profile having an age range of between 18-24 years within a particular area code who are new subscribers, confidence levels or other types of mathematical inferences can be made, to provide a simpler or more efficient representation of the entire advertisement target parameter set. It should be appreciated that other forms of correlation or manipulation may be used as deemed appropriate. Additionally, based on the processing capabilities of the mobile client and/or other practical considerations, it may be desired to refine the metric or reduce the complexity of the metric for more effective or more efficient matching. Control continues to step 2540.
  • In step 2550, a message match algorithm may be performed to determine a match metric or suitability of fit for the message target profile to the user profile. It should be apparent that this process may use any one of several possible matching algorithms described herein or known in the arts. Non-limiting examples are fuzzy logic, statistical methods, neural nets, bubble, hierarchal, and so forth. Next, in step 2560, an overall user match indication value, overall confidence level or other metric of indicating the level of suitability of the message to the user's profile can be generated. Upon a determination of the user match profile indication, which may, for example, simply be a scalar number or a “yes” or “no” value, control continues to step 2570 where the process is terminated.
  • Based on the above exemplary process 2500, advertisements and other messages designated for target populations can be matched with a user's profile to determine the suitability of the message/advertisement to the user's profile. Thus, if a high or acceptable match indication is given, the message/advertisement can be forwarded to the user in the expectation that the user will respond favorably to the message, or as per arrangements made with the user. Accordingly, advertisements/messages that are “tailored” to the user can be efficiently disseminated to the user.
  • FIG. 26 is a block diagram illustrating an exemplary user profile match indicator 2600, according to an embodiment of this invention. The exemplary user profile match indicator 2600 includes a target profile generator 2610, an advertisement server 2620, a user profile generator 2630, a profile-to-profile comparer 2640, and a storage system 2660.
  • In operation, the comparer 2640 may be housed in a user system (not shown) and can compare information forwarded by the target profile generator 2610 against information forwarded by the user profile generator 2630. The target profile generator 2610 may forward attributes related to the advertisements provided by the advertising server 2620, wherein the information/attributes can be compared to the information/attributes of the user's profile, as provided by the user profile generator 2630. Based on algorithms contained in the comparer 2640, a match indication can be formulated designating the level of suitability or confidence level of the target profile to the user profile. Based on the match indication, advertisements and/or information from the advertisement server that are consistent with the attributes of the target profile may be forwarded to storage system 2660. The storage system 2660 may be resident on the user system. Accordingly, “tailored” advertisements and/or information may be forwarded to a user without compromising the privacy of the user's profile.
  • Keyword Correlation based on past viewing history: One of the potential inputs in a match indicator calculation described above may be a correlation value derived between the previous messages viewed, i.e. a “viewing history” of the user and new messages. In this context, or messages may be associated with keywords from a dictionary at the advertisement sales interface, according to design preference. With respect to FIG. 27, a process is described that describes an exemplary generation and use of keyword associated message delivery.
  • The process starts in step 2710 and continues to step 2720 where keywords can be assigned to various messages. For example, an advertisement directed to women's apparel may have four keywords including “fashion”, “female”, “clothing” and “expensive”. The keyword(s) may be broadly associated with a genre of advertisements/messages or may be individually associated with a particular species of advertisement(s)/message(s). Thus, depending on the level of resolution or discrimination desired, more than one keyword may be associated with a particular advertisement/message or vice versus. In various embodiments, keywords may be limited to an advertisement/message dictionary or index.
  • Continuing, such keywords can be given weights (e.g., a number between 0 and 1) to help describe the strength of association between a particular message and the meaning of the keyword. If keywords are determined to not have an associated or impressed weight, their weights can be assumed to be 1/n where n is the total number of keywords associated with a message. In this manner, a gross averaging weight can be applied by the 1/n factor, in some sense to normalize the overall keyword values to within a desired range.
  • Assigned weights can provide some degree of normalization, especially in the context of multiple keywords (for example, 1/n, given n keywords, with each keyword having a maximum value of 1), or can be used to “value” the keyword or the advertisement/message according a predetermined threshold or estimation. For example, some keywords may have a higher or lower relevance depending on current events or some other factor. Thus, emphasis or de-emphasis can be imposed on these particular keywords via the weighting, as deemed appropriate. Step 2720 is presumed to have the measure of assigning a weight to the keyword as part of the keyword association for a fixed keyword value estimation. However, in some instances a weight may not have been pre-assigned or the weight valuation is undetermined. In those instances, an arbitrary value can be assigned to the keyword, for example, a weight of 1. It is presumed that these keywords are forwarded to a mobile client. Control continues to step 2730.
  • In step 2730, user response to messages may be monitored. In operation, messages can be presented to users whereupon the users may choose to “click” on them or not. As should be apparent in this technology, the term “click” can be assumed to mean any form of user response to the presence of the message or as part of an operational message sequence. In some user embodiments, a lack of response may be construed as an affirmative non-click or click-away response, analogous in some contexts to a de-selection. Thus, a mobile client user's response to various advertisements/messages can be historically gauged.
  • By monitoring the user's “click” response in relation to a general population or even a targeted population of advertisements/messages, an initial assessment of the user's interests can be obtained.
  • In various embodiments, a user's response time for a given advertisement/message or a series of advertisements/messages can also be used to gauge the user's interest therein. For example, a user may click through several advertisements/messages, each having different degrees of relevance or keywords, and the rate of click through or tunneling can be understood to be indicative of user interest. Control continues to step 2740.
  • In step 2740, a comparison of the user selection (for example, click) of a particular advertisement/message and its corresponding keyword(s) can be performed to establish at least a “baseline” correlation metric. Again, it may be noted that the selection of and/or rate of selection can be used in determining the user's interest in a keyword-associated advertisement/message. By this comparison, a correlation between the various keyword and the user's advertisement/message preference may be provided. This correlation can be accomplished using any one of several methods, such as, for example, statistical methods, fuzzy logic, neural techniques, vector mapping, principal components analysis, and so forth. From step 2740, a correlation metric of the user's response to an advertisement/message can be generated.
  • In various exemplary embodiments, a “keyword correlation engine” embedded on a message delivery system and/or W-AT may track the total number of times a particular message/advertisement may presented (or forwarded) to a user with a particular keyword (for example, N total-keyword) along with the total number of clicks for that keyword (for example, N_click-keyword). The ratio of N_click-keyword/N total-keyword may be computed to determine the correlation of the keyword to the user's response. The weight for a keyword for a message may be assumed to be 1 if the keyword is specified without an associated weight for a given message. By formulating a ratio as described above, a metric for gauging the reaction or interest of the user to a keyword tagged advertisement can be generated, and refinements or improvements to the match can be devised accordingly. In the above example, affirmative clicks can be used to indicate a user's interest. However, again it should also be appreciated that in some embodiments, a non-click or lack of direct response also may be used to infer an interest level or match relevance.
  • As an illustration of one exemplary implementation, assume that there are N keywords for a given advertisement(s). An N-dimensional vector A can be created based on the associated keyword weights. An N-dimensional correlation vector B can be created with the correlation measure of each keyword for the advertisement(s) to the user in each dimension. A scalar correlation measure C, to establish the correlation of the advertisement to the user, can then be created which is a function of the vectors A and B. The correlation measure C may be, in some embodiments, simply a dot product of the vectors A and B (C=A·B as C=(1/N) A·B). This scalar correlation measure C offers a very simple and direct measure of how well the advertisement is targeted to the specific user based on his previous advertisement viewing history. Of course, other methods may be used to correlate the A-to-B correspondence, such as parameterization, non-scalar transformations, and so forth.
  • The above approach assumes that the keyword dictionary has keywords that are independent of each other. Should the keywords be inter-related, fuzzy logic can be used to come up with a combined weight for the set of inter-related keywords. Other forms of logic or correlation can be implemented, such as polynomial fitting, vector space analysis, principal components analysis, statistical matching, artificial neural nets, and so forth. Therefore, the exemplary embodiments described herein may use any form of matching or keyword-to-user correlation algorithm as deemed necessary. Control continues to step 2750.
  • In step 2750, the mobile client or user may receive “target keyword(s)” associated with various prospective targeted messages/advertisements. Next, in step 2760, the received target keyword(s) may be evaluated to determine if there is a match or if the keyword(s) meet an acceptable threshold. In various embodiments, a matching evaluation can involve higher algorithms, such as statistical methods, fuzzy logic, neural techniques, vector mapping, principal components analysis, and so forth, if so desired. It should be appreciated that the correlation process of step 2740 and the matching process of step 2760 may be complementary. That is, different algorithms may be used with the respect processes, depending on design preference or depending on the type of advertisement/message keyword forwarded. Control continues to step 2770.
  • In step 2770, those targeted messages deemed to match within a threshold of acceptance may be forward and/or displayed to the user. The forwarding of the advertisement/message may take any one of several forms, one such form, for example, being simply permitting the matching advertisement/message to be received and viewed by the user's device. In some embodiments, a non-match advertisement/message may be forwarded to the user, but is disabled so as to prevent instantiation or viewing. Thus, in the event that the user's preferences or profile is subsequently modified, a prior non-acceptable advertisement/message but now acceptable advertisement/message may be resident on the user's device and appropriately viewed. Of course, other schemes for making available advertisements/messages that are deemed to be “matching” or “non-matching” may be devised without departing from the spirit and scope of this invention. After step 2770, the exemplary process 2700 proceeds to step 2780 where the process is terminated.
  • By use of the above exemplary process 2700, targeted advertising/messages can be filtered to be apropos to the user's interests. The user's interests can be initially established by historically monitoring the user's “click” response on the user's mobile client against a set of advertisements/messages via keyword assignment and matching. Dynamic monitoring can then also be accomplished by updating the user's interest profile, based on currently observed user response(s). Accordingly, a more direct or more efficient dissemination of targeted advertisements/messages can be obtained, resulting in a more satisfying mobile client experience.
  • Continuing, note that a significant amount of information can flow through a mobile device associated with a user during the lifetime of the device. The user may interact with some fraction of the information that is presented to it. Due to memory constraints, it may be impossible to store all such information on the mobile device itself. It may not even be feasible to store all the meta-data and the user responses associated with all such information flowing through the device as well. Thus, it may be desirable to create a user model that captures user preferences based on user behavior, so that relevant content/information can be presented to the user, without having to store all past information related to the user.
  • Accordingly, as shown in FIG. 28, it may be desirable to create a “keyword learning engine” 2810 capable of capturing user preferences and presented information. Along with the keyword learning engine, it may be desirable to have a “keyword prediction engine” 2820 based on a learned model, to suggest the likelihood of user interest for new information that is presented to the user. This could help in filtering new content as it arrives on a mobile device, so that relevant information can be presented to the user.
  • In operation, meta-data associated with information arriving at a mobile device can be used in the learning and prediction engines 2810 and 2820. Any user responses associated with presented information can be also used in the learning engine 2820. During operation, the learning engine 2810 may use all past information, e.g., meta-data and the user behavior associated with the respective presented information. Based on the input, the learn engine 2810 can refine such input to provide a learned user preference model. This user preference model may then be used in a prediction engine, which can receive meta-data related to new information, then correlate the meta-data with the user preference model to provide a predicted user match indicator/indication for the new information. This user match indicator/indication can then be used to determine whether or not the information is presented to the user.
  • It is to be appreciated that user preferences can be contextual with respect to the activity that is being learned. For example, a user may have different preferences with regard to advertisements that the user would like to see, and a different set of preferences with regard to web pages that the user would like to browse. For example, a user may read news on the web about crime in the local community news to be aware of such activity from a safety standpoint; however, that should not imply that the user would be interested in purchasing a gun through an advertisement. Therefore a message presentation engine on the platform could reflect different user preferences relative to the web browser preferences of the user. Other contexts could include user preferences related to a music application on the platform or a sports application on the platform. In general, learning and prediction engines may be required for every context.
  • In this document, an exemplary architecture and algorithm for learning and prediction for a given context, such as processing targeted-content-messages/advertisements, is provided. The suggested architecture and algorithms can be applied to different contexts without loss of generality.
  • One task at issue is to learn user preferences from a user's phone usage habits in the given context, such as learning their likes and dislikes from their response to targeted-content-messages (such as an advertisements) that are presented to the user. The goal is to provide a solution with a learning algorithm that is fast and that does not scale with amount of data presented.
  • Additionally, based on a model that is learned by the system, when a new message/information arrives at a mobile device, the available prediction engine may present a match indicator for the information relative to the learned preferences of the given user. This match indicator can be used along with other system constraints (such as revenue or size information optionally) to take a decision on whether to present the information real-time to the user, or to take a decision on whether to store the information on the user's mobile device such as in a space-constrained targeted-content-message cache on the mobile device.
  • An exemplary architectural flow is depicted in FIG. 29. As shown in FIG. 29, a message server 2620 may deliver a single message, such as a Starbucks coffee ad, to a user's mobile device 100 in real-time when the user 2990 is either walking past or driving past a Starbucks store. Based on the prediction model, it may be useful for the mobile device 100 to take a decision on whether to present this message to the user 2990 based on a match indicator value that is generated related to this information.
  • Alternatively, a stream of meta-data information related to various messages may arrive at the mobile device 100, and a resident prediction algorithm may provide the relative values of match indicators for each message, so that the mobile device 100 may take a decision on which messages to store in a space-constrained cache 240 on the mobile device 100.
  • A selection function on the mobile device 100 may optionally use additional indictors, such as associated revenue (message value calculation criteria) and size (gating and/or message value calculation criteria), in addition to a match indicator calculation using commands and information from the prediction engine 2820 to take a decision on whether to present a given message to the user 2990.
  • With regard to the learning engine 2810, for information that is presented to the user 2990, if there is a user response associated with the presented information, then both the meta-data associated with the user information and the user response may used by the learning engine 2810 to generate a learned user preference model. In addition, for the mobile device 100 of FIG. 29 individual actions on a per-message basis may or may not be stored in the mobile device 100. That is, user actions, along with meta-data for a given message may be used to refine the learned user preference model and subsequently the inputs related to the user action and the ad-meta-data are discarded from the system.
  • In various embodiments and as discussed above, it can be useful to generate and use a keyword dictionary that describes different possible preferences of a user for a given context. In operation, the creator of a targeted-content-message may specify those keywords that are relevant to a targeted-content-message in the meta-data for a targeted-content-message. When the meta-data associated with the targeted-content-message is presented to the user 2990, the learning engine 2810 may update the user's preferences related to the keywords based on the response of the user 2990 to the information. Additionally, when the meta-data (including the keywords associated with the targeted-content-message) is presented to the mobile device 100, the prediction engine 2820 may compute the match indicator for the user that can be used to determine whether or not to present the targeted-content-message to the user 2990.
  • In practical operation, one can assume that a keyword dictionary is a flat representation for the purpose of learning. Note that a keyword dictionary that is exposed to the targeted-content-message provider may either be flat or hierarchical in nature.
  • In a hierarchical representation, nodes at a higher-level in the keyword tree may represent coarse-grain preference categories such as sports, music, movies or restaurants. Nodes lower in the keyword tree hierarchy may be specify finer-grain preferences of the user such as music sub-categories rock, country-music, pop, rap, etc.
  • While a given keyword dictionary may be hierarchical, the keyword tree may be flattened starting with the bottom of the tree for the purpose of learning. For example a music node in the tree with four children {rock, country-music, pop, and rap} can be flattened to a five node representation with music (general) and the 4 sub-categories. If there are L leaves for a parent node, then the flattened representation translates to (1+L) leaves for the root of the parent node in the keyword hierarchy. Thus, the flattening of the tree can be recursively accomplished starting with the leaves of the tree all the way to the top of the hierarchy such that all intermediate nodes of the tree are connected directly to the root of the tree. For example a quad-tree representation with k levels would consist of a root node along with 4+42+43+ . . . +4(k−1) nodes. Flattening such a tree would result in a keyword dictionary tree consisting of 4+42+43+ . . . +4(k−1)=(4k−1)/(4−1)−1=4/3*(4(K−1)−1) nodes directly connected to the root node. Note that K=1 would correspond to 0 keywords, K=2 would correspond to 4 keywords, K=3 would correspond to 20 keywords, etc.
  • FIGS. 30A and 30B depict an exemplary flattening process at an intermediate parent node in the tree for a hierarchical representation. The learning and prediction algorithms may work on a weighted summation metric which effectively results in learning based on a flattened version of a hierarchical tree, if the decision making is done at the top of the tree.
  • Continuing, techniques for learning and prediction engines on mobile devices are presented. For notation purposes, let there be n keywords, each corresponding to a preference one may want to capture with regard to a user. One may abstractly represent a user's preferences as a vector P=(p1, . . . , pn), where the value pi corresponds to the user's preference level for the category i. Similarly, one can abstractly represent a message based on its relevance to the keywords as a vector A=(a1, . . . , an), where the value ai corresponds to how relevant the message is to the keyword i. One may assume that messages are presented sequentially to the learning algorithm.
  • It should be noted that typically a large number (possibly several hundreds) of keywords may be used, though most of them would be irrelevant to a particular message. It may be expected that users will have strong preferences on only a few keywords. Mathematically such vectors are called “sparse vectors”. One can assume that input training message keyword vectors are sparse. One may also assume that the desired user preference vector P is also sparse. The current estimated guess of the user's preferences based on the user model can represented as {circumflex over (P)}.
  • The algorithms for the learning and prediction engines are described below.
  • Learning Engine:
  • Input:
      • Message (represented as a vector): A
      • User response: ‘click occurred’
  • Persistent: Current guess of user preferences (as a vector): {circumflex over (P)} (initially 0)
  • Decay parameter: D
  • Counter: C (initially 0)
  • α := { 1 C if C D 1 D otherwise Eq . ( 1 ) P ^ := ( 1 - α ) P + α A Eq . ( 2 ) C := C + 1 Eq . ( 3 )
  • The estimate {circumflex over (P)} may start at initial value 0. However, in the presence of available information, one can opt to use a different starting seed. For instance, knowing the local demographics can help to seed the profile of a new mobile user to some average or amalgam. If a seed vector S is available, the initial value of {circumflex over (P)} may be set equal to the seed S with no changes to other steps.
  • Additionally it is possible that one may use a constant decay parameter α, in which case α:=1/D in Eq (2) where D is a constant.
  • Prediction Engine:
  • Input:
      • Message (represented as a vector): A
      • Current guess of user preferences (as a vector): {circumflex over (P)}
  • Return: {circumflex over (P)}·A
  • In operation, one may provide the following operational guarantees:
  • (1) If the messages and user preferences are sparse, then the learning engine can quickly learn the user preferences from user responses, e.g., the user's “clicking behavior”. That is, the rate of learning can be proportional to the sparseness of the messages and/or user preferences
  • (2) The learning engine is robust to high noise. That is, even if user clicks on a large number of irrelevant messages, as long as she is clicking on a small percentage of relevant messages, a learning engine should be able to learn the underlying preferences.
  • (3) If the underlying user preferences change over time, then the learning engine can adapt to the new preferences well.
  • Besides information-space sparseness, note that the rate of learning for the user selection rates can be determined based on rate of presentation of information, value of an initial seed, and aspects of a user profile.
  • Results from a Matlab simulation for a possible keyword learning scenario are provided in FIG. 31, which depicts a modeled learning engine in action with the horizontal axes representing the different keywords (total 500), and the vertical axes represents the strength of an individual's preference—positive implies user like, negative implies dislike. The top graph 3102 shows the underlying user preferences, while the subsequent four graphs 3104-3110 show the algorithm's best guess after receiving 50, 100, 500 and 1000 messages respectively.
  • For the simulation represented in FIG. 31, a sparse vector is randomly chosen to represent the underlying preference vector. As messages are randomly selected, the user's behavior can be simulated as follows: The user clicks on a truly relevant message about 25% of the time and rest 75% of the time the user clicks on an irrelevant message. The decay parameter D is set to 3000. Information regarding which messages were clicked is passed to a learning engine. It should be noted that for the simulation of the present example, the learning engine is not given any information about whether each message is truly relevant to the user.
  • In view of FIG. 31, it is apparent that a keyword-based user preference representation for individual learning contexts can be desirable and useful on a mobile platform. It should be appreciated that the example of FIG. 31 may be improved by a number of classic adaptive techniques. For example, it may be useful to introduce small degrees of randomness to the prediction model to refine the user's model by further exploring the user's interests in effect performing an “annealing” process characteristic of classic neural network learning.
  • Additionally, the central learning/adaptive algorithm of Eq. (2) may be modified by varying the decay parameter over time or based on the type of user response (e.g., strong positive, weak positive, neutral, weak negative, strong negative). A strong positive response may contribute positively (A/D(t)) to the estimate {circumflex over (P)} (step 6 in the learning engine). However, if a user displays some form of strong negative behavior to certain information, then the response may contribute negatively (−A/D(t)) to the estimate {circumflex over (P)}. If the user displays some form of weak positive response, then the response may contribute fractionally (α A/D(t)) to the estimate {circumflex over (P)} where 0≦α≦1. Similarly, a weak negative response may contribute negatively and fractionally (−α A/D(t)) to the estimate {circumflex over (P)} where 0≦α≦1.
  • Alternatively, the central learning/adaptive algorithm of Eq. (2) may be modified by imposing estimate {circumflex over (P)} limits, i.e., ceilings and floors, for particular keywords, either by a system operator or in response to certain user behavior. For example, a strong negative user reaction, e.g., some instruction to never show such type of message again, may impose a ceiling for one or more keywords.
  • Still further, it should be appreciated that, in various embodiments, training parameters and/or learning rules can be embedded in a given message, which can reflect the correlation strength of the message to the keyword. For example, a first advertisement having three related keywords KW1, KW2 and KW3, Keyword KW1 may be far more closely coupled to the content of the advertisement compared to keywords KW2 and KW3. Assuming that respective decay parameters of 500, 2500 and 3000 are transmitted with the advertisement, selection of the advertisement may cause a prediction model to change the respective estimate {circumflex over (P)}KW1 far faster than for {circumflex over (P)}KW2 and {circumflex over (P)}KW3.
  • Note that the prediction engine may be designed to require that a baseline correlation metric exceed a threshold value to determine relevancy of the target message to the user. For example, in lieu of FIG. 31 it may be desirable to only use keywords associated with estimates that exceed 0.25 and/or are below −0.20 to select messages.
  • Similarly/alternatively, it may be desirable to only use the top 10 values keywords and/or the bottom 5 keywords to select messages. Such simplification of prediction models may improve performance and reliability of a mobile message delivery device by eliminating the effects of user selection “noise.”
  • Finally, while Eqs (1)-(3) are representative of what is known as an “LMS steepest descent” adaptive/learning algorithm, it should be appreciated that other learning algorithms may be used, such as a Newtonian algorithm or any other known or later-developed learning technique.
  • FIG. 32A and FIG. 32B outline an exemplary operation for a mobile client to perform various learning and predictive processes. The process starts in step 3204 where a set of keywords are assigned. As discussed above, the set of available keywords may be sparse or not sparse and/or arranged in a hierarchical or non-hierarchical/flat relationship. Next, in step 3206, the set of keywords may be downloaded to a mobile client, e.g., a cellular phone or wireless-capable PDA. Then, in step 3208, a set of seed values may be downloaded onto the mobile client. In various embodiments, such seed values may include a set of zero values, a set of values determined based upon known demographics of the user, or a set of values determined by any of the other processes discussed above with regard to initial/seed values. Control continues to step 3210.
  • In step 3210, a set of first messages may be downloaded onto the mobile client, along with the appropriate meta-data, e.g., keywords and (possibly) keyword weights, and/or any number of learning models, e.g., a modified steepest descent algorithm, and/or any number of learning parameters, such as the decay parameter discussed above, ceiling limits, floor limits, context constraints, and so on. Note that while the present set of operations allow for messages to be downloaded at the same time as meta-data and other information, in various embodiments messages may be downloaded after the mobile client determines that such messages are suitable via any number of gating or valuation operations. Control continues to step 3212.
  • In step 3212, a number of prediction operations may be performed to predict messages, such as targeted advertisements, that would likely be of interest to a user noting that such a prediction operation could be based on a learned model constructed from the seed values of step 3208. Next, in step 3214, the desirable message(s) could be displayed (or otherwise presented) on the mobile device. Then, in step 3216, the mobile device could monitor user responses, e.g., observe and possibly store click-through rates, to the displayed message(s). Control continues to step 3220.
  • In step 3220, a set of one or more learning algorithms may be performed to update (or otherwise determine) the various learned models to establish one or more sets of learned user preference weights. Note that, as discussed above, learned models may be provided for a variety of context, may use any number of adaptive processes, such as an LMS operation, may incorporate algorithms and learning parameters for particular messages and so on. Control continues to step 3222.
  • In step 3222, a set of second/target messages may be downloaded onto the mobile client, along with the appropriate meta-data, and/or any number of learning models, and/or any number of learning parameters. Again, note that while the present set of operations allow for messages to be downloaded at the same time as meta-data and other information, in various embodiments, messages may be downloaded after the mobile client determines that such messages are suitable via any number of gating or valuation/prediction operations. Control continues to step 3224.
  • In step 3224, a number of prediction operations may be performed to predict messages, such as targeted advertisements, that would likely be of interest to a user noting that such a prediction operation could be based on the learned model of step 3220. Next, in step 3226, the desirable message(s) could be displayed (or otherwise presented) on the mobile device. Then, in step 3228, the mobile device could monitor user responses, e.g., observe and possibly store click-through rates, to the displayed message(s). Control then jumps back to step 3220 where after steps 3220-3228 may be repeated as necessary or otherwise desirable.
  • Application to Statistics Generation—in various exemplary embodiments, a user preference vector may have N dimensions, but only some subset of M dimensions may be relevant to the user. A sparse set of K dimensions can be randomly selected from the N dimensions, and the user preference values associated with the chosen K dimensions may be transmitted. Assume that there are U users in the population for a certain demographic type (such as teenagers). If all U users transmitted all N dimensional values to a server, then each dimension may have available U samples to determine statistics associated with the dimension (such as a mean or variance). However, if only sparse (K-dimensional) components are transmitted, then, on an average, Uk/N samples may be available for each dimension. As long as U>>N, then there are sufficient samples available to compute statistics for each dimension, without requiring each user to transmit all N components of its preference vector. Additionally, if only a fraction r of users transmit information, then on an average Ukr/N samples may be available for each dimension. Thus, one can maintain a sufficient degree of privacy of information for each user while gathering statistics over an entire population of users.
  • Cache Miss History Attribute: Every time a particular message/ad is requested from a cache and there is no message/ad in the cache satisfying the message/ad type requested, it is a missed opportunity to show an appropriate message/ad to the user. Thus, there is a need to give more weighted value to message that are of the type for which the cache has recorded misses in the recent past. In various embodiments, a parameter, such as the cache miss state match indicator (FLAGCACHE MISS MI) discussed above, can work to avoid such missed opportunities by aiding message/ad value calculation. In various embodiments, this attribute works to determine whether a new prospective message matches the most recent recorded cache misses. It may be a logical “1” (or equivalent) if it matches one of the recent cache misses and a logical “0” (or equivalent) otherwise. This flag may be reset once the message is accessed by an application from the cache and served to the user. If a new message is selected for cache entry, the cache miss entry can be removed from the list of recorded cache misses.
  • Filter rules: Filter rules may be used by a System Operator to drive the operation of a filtering agent. This allows the System Operator to control the functionality of the filtering agent in a dynamic fashion. Filter rules may be of different types and used to drive different functionalities of the filtering subsystem. Some typical use cases may include:
      • Filter rules that may determine message cache ratios used to divide a cache space into different categories based on different classifications. The cache ratios may be fixed or dynamic based on some defined criteria.
      • Filter rules that may determine the value calculation formula for each category.
      • Filter rules that may define λ which is the value decay rate based on time for messages.
      • Filter rules that may be used to specify any of the coefficients/weights that go into the calculation of a final message value from the message value attributes within a category.
      • Filter rules that may define the match indicator calculation formula.
      • Filter rules that may define a cache miss state match indicator calculation formula.
      • Filter rules that may define a message playback probability indicator calculation formula.
      • Filter rules that may define the minimum confidence level threshold below which random CTR are calculated on the device.
      • Filter rules that may define the number of default messages to be stored for each message type.
  • Architecture: Depending upon different message distribution models, gating and message selection sub-processes might be implemented by different agents that exist either on a server or on a client. The following sections below discuss the possible architectures for message filtering based on different ad distribution mechanisms.
  • Multicast/Broadcast Message Distribution: FIG. 33 is an illustration of a Multicast/Broadcast Message Distribution scenario using a W-AT 100 and a multicast/broadcast message distribution server 150-A. In case of multicast distribution, messages (e.g., ads), respective metadata and messages filtering rules can be distributed by a message delivery network over a broadcast or multicast channel to a number of users. Consequently, the filtering and caching of messages targeted to the user profile of the user may take place on the W-AT 100 along with any gating and selection sub-processes of the filtering process.
  • Unicast Message Distribution: There are a number of different protocols that can be used to implement unicast fetch of messages from a message distribution server. Based on the information available at such a server, the gating and selection process can reside on either the server or the various mobile devices. The following is a discussion on some of the protocols and the corresponding message filtering architecture that may be implemented in each case.
  • Unicast Message Distribution—Protocol 1: FIG. 34 illustrates a first exemplary unicast message distribution scenario using W-AT 100 and a unicast message distribution server 150-B. In operation, the W-AT 100 can send a “message pull” request to the server 150-B whereby the server 150-B can respond with all the messages available within the system. This approach can hide the mobile device's user profile from the server 150-B by generating and maintaining the profile on the W-AT 100. However it could be expensive to deliver messages to a client over a unicast session if there is a likelihood of a significant portion of the messages being rejected because of non-match with the mobile device's user profile. As in the multicast distribution case, the filtering and caching of messages targeted to the user profile of the W-AT 100 may take place on the W-AT 100 along with the gating and selection sub-processes of the filtering process.
  • Unicast Message Distribution—Protocol 2: FIG. 35 illustrates a second unicast distribution scenario using W-AT 100 and unicast message distribution server 150-C. In this scenario a user profile can be generated on the W-AT 100 but can be in-sync with server 150-C in that identical copies of the user profile can reside on both devices 100 and 150-C. The device profile of W-AT 100 may also be in-sync with the server 150-C and hence, upon receiving a message pull request from the W-AT 100, the server 150-C can readily push only targeted messages to the device. The gating process—as well as parts of the selection process based on determining whether the messages can be targeted towards the user profile of the W-AT 100—can be implemented on the server 150-C. The message value determination and replacement of old messages by higher-valued new messages can be implemented on the W-AT 100.
  • In operation, any syncing procedures of the user and device profile between the W-AT 100 and the server 150-C may take place out-of-band using a separate protocol, or in certain embodiments the profiles might be included in the message pull request from the client.
  • Unicast Message Distribution—Protocol 3: FIG. 36 illustrates a third exemplary unicast message distribution scenario using W-AT 100 and unicast message distribution server 150-D. In operation, a user profile can be maintained on the W-AT 100, but only the device profile is synced with the server 150-D while the user profile remains only within W-AT 100. Correspondingly, the gating process can be implemented on the server 150-D, and the server 150-D may push only messages to the W-AT 100 that have cleared the gating process. Part of the gating process, based on system operator specified filters (if any) that require the user's profile, can be implemented at the W-AT 100. Further, the selection process can be implemented completely at the W-AT 100.
  • As with Protocol 2, the sync of the device profile between the W-AT 100 and the server 150-D might take place out-of-band using a separate protocol or the profile might be included in the ad pull request from the client.
  • Unicast Message Distribution—Protocol 4: FIG. 37 illustrates a fourth unicast message distribution scenario using W-AT 100 and unicast message distribution server 150-E. In this scenario, upon receiving a message pull request from the W-AT 100, the server 150-E can respond back with metadata for messages that clear the appropriate gating process. Hence, the gating process can be implemented on the server 150-E. Continuing, the selection process can be implemented at the W-AT 100 using the metadata provided by the server 150-E. Part of the gating process, based on system operator specified filters (if any) that require the user's profile, can be implemented at the W-AT 100. Next, the W-AT 100 may respond to server 150-E with a message selection requests for those messages that the W-AT 100 decides to display or store in its cache based upon the selection process, and the server 150-E may provide those selected messages to the W-AT 100.
  • Again, the device profile or the gating parameters might be included in an initial message pull request by the W-AT 100, or alternatively might be synchronized between the W-AT 100 and the server 150-E out-of-band using a separate protocol.
  • Processing/Synthesizing Captured Location Data to Affect a User Profile
  • Location information may often be used to derive indicators of personal demographics. In the case of mobile communication devices, location data may sometimes be a better indication of demographic data concerning the user than billing information. In addition to constraints on the use of billing information, the billing information may not include sufficient data to indicate the desired demographics. Further, home demographics may be only partially indicative of the message-related interests of the user. If, for example, the user maintains two residences, or tends to frequent particular locations, this may not be indicated by home demographics. Thus, for example, services and products related to a particular work or recreational location may not be reflected by the home-location derived demographics of a user, but still be very useful.
  • It is understandable that a user may not wish to release his/her location information in order to preserve privacy or may consider it overly intrusive. However, by retaining the capability to gather location information and perform location-based matching by a mobile client, it is possible to attain the information required for demographic targeting within the mobile device and still preserve privacy. Thus, for example, if the user frequents a particular recreational area with an appropriately enabled mobile device, such as a cell phone with access to GPS information, the appropriate information for the user's recreational interest may be derived and/or synthesized without bothering the user and/or breaching the user's privacy. This information may then be used to derive and/or update a user profile resident to the mobile device, which in turn may be used to determine which targeted content messages may be downloaded and/ore displayed on the mobile device. Conceptually, this can result in placement of advertising and other information in a manner appropriate to the location information associated with a user, based on actual detected locations, but without providing the location information to an external agent.
  • In operation, location information may be stored using a database resident to a mobile device. The stored data may include raw location data, but also in various embodiments include data regarding: specific locations area locations, clusters of locations, path information from various locations to other locations, location-types in combination with values associated with time intervals, and time probability distributions of specific location types.
  • Continuing, in many cases, user action may be insufficient to indicate a particular activity, but user actions may be relevant if such actions can be linked with one or more various sets of location data. Taking the example of a person who frequents a recreation area, but usually enters the recreation area by entering a particular roadway. Data concerning use of that roadway would not by itself be indicative of much beyond the use and existence of the roadway, and would not by itself have any associations with the recreation area. However, by coupling/correlating the individual's location history and the present action of entering the roadway, it is possible to establish a statistically significant probability that the individual is en route to the recreational area. Thus, particular location information can be correlated with activities associated with other particular locations. Continued examples include recreational areas, parts of a city, entertainment locations (especially in combination with time-of-day information), geographical location in combination with time-of-day associated with work, and locations associated with shopping. These can be combined with identification of clusters of locations and time intervals. The locations can be used in combination with path analysis, which can be useful in establishing an association of present location (or movement) with other stored data, e.g., present location, location history and path activity can be used to identify a likelihood of a particular activity, and thus enable a message provider to target messages before a user engages in a particular activity. For example, by measuring various locations on a GPS-enabled mobile client, the mobile client may determine that the user has left work and is on-route to a shopping center the user frequents. In response, a MAS (or other targeted content delivery system) may automatically forward information relating to products in which the user may be interested, as well as provide advanced traffic information for various routes to the shopping center.
  • Continuing, in various embodiments, it may be useful to identify various businesses, for example those based on a particular highway, to a user traversing the highway. In such instances, targeted advertisements or other information based on determination of the consumer's activities may be provided. This approach is particularly advantageous in circumstances where the customer has limited access to his mobile device, but authorizes the particular business or genre of businesses to provide information.
  • In various embodiments, a significant aspect of the system may include that tracking of an individual may be performed within the mobile device and retained within the mobile device. In one configuration, no external party is privy to the tracking information. Taken further, the profiling necessary to match the tracking information associated with various targeted content can be performed within the mobile device. Again, by limiting personal information to a user's mobile device, it is likely that the user may find this form of profiling acceptable because it is not performed externally.
  • Note that, in various embodiments where circumstances permit, it may be possible and/or advantageous to mesh a mobile client with resources available in other devices, such as a GPS-based navigation device of many automobiles. Thus, with little more than software modification(s) (depending on the particular embodiments) enabling a mobile device to communicate to one or more of an automobile's systems, GPS and other information may be shared. Generally, such an automobile and mobile client may communicate using a Bluetooth or similar wireless interface commonly found in such devices. Thus, as location information for the mobile client is provided by the automobile's GPS/navigation device, the mobile device's resident user profile may be updated without the expense of a GPS system built in to the mobile device.
  • Note that, in addition to automobiles, a particular mobile device may derive location information from a variety of alternate sources, such as a remote server or other nearby device, to receive location information. For example, a mobile client may come into contact with an 802.11 network residing in a coffee shop, or perhaps a string of local wireless networks within a city whose locations are known or capable of being derived, to determine location information.
  • Note that, in various embodiments, a mobile client can choose the source of information based on the energy level of the mobile client/device, e.g., a low battery charge. Also note that location history can be obtained based on periodic measurements where the period of measurements is allowed to vary, or based on random measurements, or a combination of random and periodic measurements. A mobile client may also chose to change the rate of GPS capture based on available energy, e.g., slow the GPS capture rate with intermittent power down on low battery conditions, as well as change the rate that it might tap into other available data sources, e.g., the accelerometer and/or speedometer of an automobile to which the mobile client has access.
  • FIGS. 38A-38H depict information screens 3800-A . . . 3800-H captured by a GPS-enabled cellular phone of a particular user displayed with various points of interest. As shown in these figures, each information screens 3800-A . . . 3800-H includes a map 3810, a set of controls 3820, a calendar display 3830, a daily histogram 3840 and a weekly histogram 3850.
  • In operation, a user (or automated program) may set each control in the set of controls 3820 for establish GPS sampling times and the display of GPS information for the map 3810, the calendar 3820 and the histograms 3840 and 3850 noting that while histogram 3840 is a daily histogram divided into time slots of one hour and the weekly histogram 3850 is divided into slots of one day, such captured location data may be organized into any number of histograms including a daily histogram showing particular locations, areas, clusters of locations and even information representing past paths taken that the user had experienced over the course of various time periods, e.g., weekdays, weekends, individual days, whole weeks, whole months and so on. Note that the calendar 3830 may also be considered a histogram.
  • Also note that, by selecting a particular location icon, such as location 3850 or 3852 of FIG. 38A, the data of histograms 3840 and 3842, as well as the numbers populating the calendar 3830, can change to reflect GPS data commensurate with collected GPS data. Continuing to FIG. 38C, a particular location may be identified (either by a mobile client's user or by some estimation software in the mobile client) as a user's residence 3854, and similarly in FIG. 38E a particular location may be identified as the user's workplace 3856.
  • In view of FIGS. 41A-41H, it should be apparent that location information captured by a GPS-enabled cellular phone may be used to generate user profile information enabling resident software to determine both: (1) the likelihood that a user will be at a particular location or traveling along a particular path at a given time frame, e.g., an employee be at a work location at 4:00 pm; (2) the likely timeframe that the user will leave a particular starting location at a given time, e.g., the employee leave a work location at 5:00 pm, and (3) the likely timeframe that the user will be at a particular second location or use a path (or set of locations or paths), e.g., the employee use a particular road at 5:30 pm and reach his residence between 6:00 pm and 6:30 pm.
  • Note that likelihood information may be expressed in a large variety of ways. For example, a time likelihood may be expressed as a particular point in time, a Gaussian distribution centered on particular point in time and with a particular variance; a continuous probability distribution function (PDF) having a unique form based on past user activity; a discrete PDF measured in contiguous time periods (“time buckets”) with the time buckets being of equal or unequal size, and so on.
  • Using such information, an appropriately enabled mobile client may also determine points of interest for the user, such as the user's likely location for his home, work, hobbies, place of religious worship and so on, as well as the likely times that the user will be at such locations and other likelihood information for such points of interest (e.g., likely times of arrival and departure). Such information may then be used to shape or modify user profile information in his mobile client, and as mentioned above, the resultant user profile may be used to determine what information (e.g., advertisements, coupons, etc.) would most likely interest the user, which in turn may lead to specific target information being stored and/or displayed on the mobile client.
  • Continuing, FIG. 39 and FIG. 40 depict an exemplary number of operations for an example of a user leaving a work location LW at the end of a work day. The probabilities concerning the various locations, i.e., starting location LW and prospective destination locations L1-L8, along with the probabilities of using the respective paths/roads R1-R8 between locations L1-L8, can be assumed to be developed using past behavior of the user, sensed using GPS and other technology, and incorporated into the user's mobile client.
  • Starting with FIG. 39, the user is assumed to be at starting/work location LW shortly before the end of his work day. Based on the user's past behavior, a user profile in his mobile client can determine that the user is likely to leave work at 5:00-5:15 pm and head to any of prospective destination locations L1-L8 noting that in the present example the probability of heading to locations L7-L8 falls below a particular threshold and should not be considered.
  • Assuming that the probability of the user heading to location L1 and L6 are both 0.1, the probability of the user using roads R7 and R8 are also both 0.1. Assuming that the probability of the user's final destination for the remaining destinations of interest are L2=0.1, L3=0.1, L4=0.4, and L5=0.2, (which assumes a 0.1 probability that the user stays at work), the probability that the user uses road R1 is 0.7. Thus, it is apparent that likely routes of the mobile client's user may be based on spatial relationships of the mobile client's current location LW in relation to the most likely destination locations L1-L8, as well as the spatial relationships between the most likely destination locations L1-L8.
  • Note that the user profile of the user's mobile client may be formed and updated by correlating past time data of the user's location history to form a time probability distribution of the user's past presence and movement for the work location LW and/or any other location to which the user may have visited; the result being a probability density function (or facsimile thereof) of the presence of the user at a given location as a function of time. Such a user profile may determine any and all of the current most likely probable destinations L1-L6 under consideration by the user as a function of time and/or present location.
  • Also note that any of the most probable current destinations may be an amalgam or cluster of a plurality of past identified destinations of the user. For example, location L5 may actually consist of three separate locations closely spaced together with the assumed location inform being a centroid (based on a weighted geographical average) or general area of the three location. Similarly, locations L3-L5 might be combined into an amalgam location assuming locations L3-L5 are reasonable proximate/clustered relative to one another.
  • Returning to FIG. 39, again the user's mobile client may determine the most probable destinations based on the time of day, the user's present location and other current observations taken by the mobile client, as well as those past observations incorporated into the user profile. Such “other current observations” may include things such as recent phone and texting activity. For example, if the user receives a call from his wife at 4:30 pm, it may indicate an increase likelihood that the user may need to go to a store before heading home, thus changing the probabilities for the current likely destinations L1-L6. Similarly, if the user shows no interaction with his mobile client, it may indicate a likelihood that the user may delay his departure from location LW.
  • Continuing to FIG. 40, note that the probability of heading to any of the various current likely destinations L1-L6 may be updated based on “en route” accumulated measures of location change by the mobile client after leaving the first location LW. That is, as new data is received, the various probabilities may need to be re-assessed. For the example of FIG. 40, this is reflected in changes in the probabilities of going to destinations L1 and L6, as well as the probability of the user staying at location LW, becomes negligible given that the user is determined to be on road R1 by his mobile client. Thus, the probabilities of going to destinations L1 and L6 or staying at location LW may be discounted from further consideration. Meanwhile, the probability of reaching any of locations L2, L3, L4, L5, L8 and L8 may increase noting that the likelihood of the user reaching location L2 is near unity (due to its spatial relationship with both the user and the other current destination locations L3, L4, L5, L8 and L8) even if the user makes no stop at location L2. Thus, determining a likely transition time, e.g., the time of leaving a first location or arriving at another location, may be accomplished using an adaptive weighted allocation based on other en route events.
  • Note that, in various embodiments, a kth order Markov model (where k is an integer greater than 1) incorporated into the mobile client may be used to determine any of the probabilities discussed above. Continuing to FIG. 41, an exemplary Markov model 4100 is depicted for the user's starting location LW and prospective destination locations L1-L8 of FIG. 39 and FIG. 40. As shown in FIG. 41, the locations LW and L1-L8 are interconnected with paths, and each path has a probability PN-M. Again, note that each probability PN-M can be derived from a user profile and vary as a function of the current location of a user, a transition event and/or time of day. Also note that there may be time-varying probabilities PN-N of the user staying at location LN for a given period, e.g., the likelihood of the user remaining at a grocery store (upon reaching it) may have a Gaussian distribution centered at 20 minutes with a 10 minute variance.
  • FIG. 42 is diagram of a process flow outlining an exemplary operation for updating the user profile based on an NFC transaction. The process starts in step 4202 where a mobile client may be programmed to sample location information using an available GPS (or other suitable location finding device) and/or any of local wireless cellular networks, local available LANs, and so on, according to predetermined or adaptive sampling frequencies and periods. Next, in step 4204, the captured information may be processed/synthesized to identify points, areas of interest, paths taken or any other location and/or path data. Then, in step 4206, the information may be further processed/synthesized to determine likely locations and/or likely paths for particular time periods—as well as complementary information of likely time periods for a given location or path. Control continues to step 4208.
  • In step 4208, a user profile residing in the mobile client can be updated using special software resident in the mobile client. In various embodiments, such user profile information, which includes information derived from past observations of the user, may be used to create some form of probability model of the user's likely behavior for a given time of day and current location.
  • Next, in step 4210, the mobile client may derive (directly or using secondary resources, e.g., an automobile's GPS) any and all of the recent/current observation data discussed above, such as location, time, transition/movement, sensor (e.g., speedometer) data, as well as information related to the user's current and/or recent behavior, e.g., the mobile client observes the user sending text messages. Next, in step 4512, the mobile client may process the information of step 4210 and the information within the user profile using any of the techniques discussed above, to identify likely destinations, transition times and/or paths (or changes to previously determined probabilities) that the user will likely take based on the user's current location and time. Then, in step 4214, the mobile client may select and/or display information, e.g., advertisements, coupons etc, based on the user profile, the data collected in the previous steps and any probability data derived. Control then jumps back to step 4210 where any or all of steps 4210-4214 may be repeated as may be found necessary or desirable.
  • The techniques and modules described herein may be implemented by various means. For example, these techniques may be implemented in hardware, software, or a combination thereof. For a hardware implementation, the processing units within an access point or an access terminal may be implemented within one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing W-ATs (DSPDs), programmable logic W-ATs (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, other electronic units designed to perform the functions described herein, or a combination thereof.
  • For a software implementation, the techniques described herein may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in memory units and executed by processors or demodulators. The memory unit may be implemented within the processor or external to the processor, in which case it can be communicatively coupled to the processor via various means.
  • In one or more exemplary embodiments, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that may be accessed by a computer. By way of example, and not limitation, such computer-readable media may comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to carry or store desired program code in the form of instructions or data structures and that may be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (“DSL”), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (“CD”), laser disc, optical disc, digital versatile disc (“DVD”), floppy disk, High Definition DVD (“HD-DVD”) and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
  • The previous description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the features, functions, operations, and embodiments disclosed herein. Various modifications to these embodiments may be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from their spirit or scope. Thus, the present disclosure is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.

Claims (53)

1. A method for determining a suitability for a mobile client to display information, comprising:
receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages;
monitoring user interaction of the respective first messages on the mobile client;
determining a user selection rate for each unique first keyword of the plurality of sets of first keywords;
receiving a set of target keywords associated with a target message;
performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters; and
displaying the target message on the mobile client dependent upon the matching parameters.
2. The method according to claim 1, further comprising receiving the target message over a wireless link if the one or more matching operations indicate a desirability of the target message.
3. The method according to claim 1, wherein determining a user selection rate includes monitoring interaction of a user of the mobile client and a plurality of the first messages.
4. The method according to claim 3, wherein determining a user selection rate includes monitoring a lack of user interaction, the lack of user interaction indicating a level of user interest.
5. The method according to claim 3, wherein determining a user selection rate for each keyword includes monitoring click-through-rates for each keyword from a plurality of the first messages.
6. The method according to claim 5, wherein the step of determining a rate of user selection is performed on the mobile client.
7. The method according to claim 6, wherein performing one or more matching operations is performed on the mobile client.
8. The method according to claim 1, wherein each target keyword of each set of one or more first keywords has a relative weight associated with its respective first message, and the one or more matching operations is based on the relative weights.
9. The method according to claim 8, wherein each relative weight of a keyword with a particular first message is 1/n, where n is the total number of keywords associated with the particular message.
10. The method according to claim 8, wherein at least one relative weight of a keyword with a particular first message is based on one or more current events.
11. The method according to claim 8, wherein the one or more matching operations is based on a baseline correlation metric.
12. The method according to claim 11, wherein the baseline correlation metric is determined based on at least one of a statistical method, fuzzy logic, neural techniques, vector mapping, vector space analysis, support vector machines, and principal components analysis.
13. The method according to claim 1, wherein the user selection rate for each keyword adapts to changes in user behavior
14. The method according to claim 1, wherein dependencies exist between target keywords.
15. The method according to claim 1, wherein the user selection rates determined do not exactly correspond to the true user preferences.
16. The method according to claim 1, wherein a rate of learning for the user selection rates is determined.
17. The method according to claim 16, wherein the rate of learning for the user selection rates is determined based on at least one of information-space sparseness, rate of presentation of information, value of initial seed, and aspects of a user profile.
18. The method according to claim 1, wherein a set of user selection rates are determined for a first context, and a second set of user selection rates are determined for a second context.
19. The method according to claim 1, wherein the keywords are specified from a specified hierarchical keyword dictionary, wherein the hierarchy has two or more levels.
20. The method according to claim 1, wherein the keywords are specified from a specified flat keyword dictionary.
21. The method according to claim 1, wherein the keywords are not associated with the semantics of a specific language.
22. The method according to claim 1, wherein one or more matching parameters are modified based on a random or pseudo-random probability.
23. The method according to claim 19, wherein a cardinality of the set of target keywords is sparse relative to the size of the keyword dictionary.
24. The method according to claim 20 wherein a cardinality of the set of target keywords is sparse relative to the size of the keyword dictionary.
25. The method according to claim 5, wherein a new user selection rate for a keyword is determined based on a weighted average between a previous user selection rate and user behavior associated with a plurality of the first messages.
26. The method according to claim 1, wherein the previous user selection rate is determined based on an initial seed profile
27. The method according to claim 26, wherein a user-provided preference indicator is used as the previous user selection rate.
28. The method according to claim 11, wherein the baseline correlation metric is required to exceed a threshold value to determine relevancy of the target message to the user.
29. The method according to claim 11, wherein the baseline correlation metric is based on using a subset of keywords relative estimates.
30. The method according to claim 4, wherein determining a user selection rate includes monitoring the type of user interaction, the type of user interaction indicating level of user interest.
31. The method according to claim 1, wherein a mobile client communicates user selection rates for a random sparse set of keywords to an external entity on a network to enable gathering of statistics across a population.
32. The method according to claim 31, wherein the random sparse sets are chosen differently across mobile clients to enable gathering of statistics on all keywords across a plurality of mobile clients.
33. The method according to claim 32, wherein a fraction of mobile clients in the plurality of mobile clients communicate user selection rates for at least one of the random sparse set of keywords to the external entity on a network.
34. A mobile client configured to display information, comprising:
a receiving circuit configured to receive a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message;
a monitoring agent configured to monitor user interaction of the respective first messages on the mobile client;
a determining agent configured to determine a user selection rate for each unique first keyword of the plurality of sets of first keywords;
a filtering agent configured to perform one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters; and
a display configured to display the target message on the mobile client dependent upon the matching parameters.
35. The mobile client according to claim 34, wherein the receiving circuit is further configured to receive the target message over a wireless link if the one or more matching operations indicate a desirability of the target message.
36. The mobile client according to claim 34, wherein each target keyword of each set of one or more first keywords has a relative weight associated with its respective first respective message, and the one or more matching operations is based on the relative weights.
37. The mobile client according to claim 34, wherein the determining agent is configured to determine the user selection rate by monitoring interaction of a user of the mobile client and a plurality of the first messages.
38. The mobile client according to claim 37, wherein the determining agent is configured to determine the user selection rate by monitoring click-through-rates of a plurality of the first messages.
39. The mobile client according to claim 37, wherein the determining agent is configured to determine the user selection rate by monitoring a lack of user interaction, the lack of user interaction indicating user interest.
40. The mobile client according to claim 36, wherein each relative weight of a keyword with a particular first message is 1/n, where n is the total number of keywords associated with the particular message.
41. The mobile client according to claim 36, wherein at least one relative weight of a keyword with a particular first message is based on one or more current events.
42. The mobile client according to claim 36, wherein the one or more matching operations is based on a baseline correlation metric.
43. The mobile client according to claim 34, wherein the baseline correlation metric is determined based on at least one of a statistical method, fuzzy logic, neural techniques, vector mapping, and principal components analysis.
44. A mobile client configured to display information, comprising:
means for receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages, the receiving circuit further configured to receive a set of target keywords associated with a target message;
means for monitoring user interaction of the respective first messages on the mobile client;
means for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords;
means for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters; and
a display configured to display the target message on the mobile client dependent upon the matching parameters.
45. The mobile client according to claim 44, wherein each target keyword of each set of one or more first keywords has a relative weight associated with its respective first respective message, and the one or more matching operations is based on the relative weights.
46. The mobile client according to claim 44, wherein the means for determining determines a user selection rate by monitoring interaction of a user of the mobile client and a plurality of the first messages.
47. The mobile client according to claim 46, wherein the means for determining determines a user selection rate by monitoring click-through-rates of a plurality of the first messages.
48. The mobile client according to claim 46, wherein the means for determining determines a user selection rate by monitoring a lack of user interaction, the lack of user interaction indicating user interest.
49. The mobile client according to claim 46, wherein each relative weight of a keyword with a particular first message is 1/n, where n is the total number of keywords associated with the particular message.
50. The mobile client according to claim 46, wherein at least one relative weight of a keyword with a particular first message is based on one or more current events.
51. The mobile client according to claim 46, wherein the one or more matching operations is based on a baseline correlation metric, and wherein the baseline correlation metric is determined based on at least one of a statistical method, fuzzy logic, neural techniques, vector mapping, and principal components analysis.
52. A mobile client for determining a suitability for displaying information, comprising:
a memory;
a transceiver;
a processor linked to the memory and operable to:
receive via the transceiver a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages;
monitor user interaction of the respective first messages on the mobile client;
determine a user selection rate for each unique first keyword of the plurality of sets of first keywords;
receive a set of target keywords associated with a target message;
perform one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters; and
display the target message on the mobile client dependent upon the matching parameters.
53. A computer program product, comprising:
a computer-readable medium comprising:
instructions for receiving a plurality of sets of one or more first keywords on a mobile client, each set of first keywords associated with one or more respective first messages;
instructions for monitoring user interaction of the respective first messages on the mobile client;
instructions for determining a user selection rate for each unique first keyword of the plurality of sets of first keywords;
instructions for receiving a set of target keywords associated with a target message;
instructions for performing one or more matching operations between the set of target keywords and corresponding user selection rates to produce a set of one or more matching parameters; and
instructions for displaying the target message on the mobile client dependent upon the matching parameters.
US12/268,914 2007-11-14 2008-11-11 Method and system for keyword correlation in a mobile environment Abandoned US20090125517A1 (en)

Priority Applications (34)

Application Number Priority Date Filing Date Title
US12/268,914 US20090125517A1 (en) 2007-11-14 2008-11-11 Method and system for keyword correlation in a mobile environment
KR1020107013070A KR101195630B1 (en) 2007-11-14 2008-11-14 Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
EP08851034A EP2225861A1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
PCT/US2008/083672 WO2009065064A1 (en) 2007-11-14 2008-11-14 Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
PCT/US2008/083657 WO2009065052A1 (en) 2007-11-14 2008-11-14 User profile match indication in a mobile environment methods and systems
CN201710372528.5A CN107196851A (en) 2007-11-14 2008-11-14 There is the method and system of the suitability of the content-message of target for determination
CN200880123706.XA CN101911618B (en) 2007-11-14 2008-11-14 Method and system for message value calculation in a mobile environment
EP08849499A EP2225858A1 (en) 2007-11-14 2008-11-14 Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
PCT/US2008/083680 WO2009065071A1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
PCT/US2008/083650 WO2009065045A1 (en) 2007-11-14 2008-11-14 Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
CN2008801239309A CN102017550A (en) 2007-11-14 2008-11-14 Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
JP2010534247A JP5209733B2 (en) 2007-11-14 2008-11-14 Method and system for using keyword vectors and associated metrics to learn and predict user correlation of targeted content messages in a mobile environment
EP08848766A EP2232798A1 (en) 2007-11-14 2008-11-14 Method and system for message value calculation in a mobile environment
JP2010534243A JP5134091B2 (en) 2007-11-14 2008-11-14 Method and system for determining user suitability of a target content message using a cache missed state match indicator in a mobile environment
EP08850179A EP2225860A1 (en) 2007-11-14 2008-11-14 Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
CN200880123907.XA CN101911620B (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
JP2010534234A JP5762746B2 (en) 2007-11-14 2008-11-14 Method and system for determining a geographic user profile to determine the suitability of a target content message based on the geographic user profile
CN200880123867.9A CN101911619B (en) 2007-11-14 2008-11-14 For upgrading the method and apparatus of the memory content in mobile client
CN200880123906.5A CN102119513B (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
KR1020107013073A KR101161078B1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
PCT/US2008/083676 WO2009065067A1 (en) 2007-11-14 2008-11-14 Method and system for message value calculation in a mobile environment
KR1020107013114A KR101172968B1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
EP08849548A EP2225859A1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
EP08850889A EP2223479A1 (en) 2007-11-14 2008-11-14 User profile match indication in a mobile environment methods and systems
JP2010534240A JP5345631B2 (en) 2007-11-14 2008-11-14 Method and system for using keyword vectors and associated metrics to learn and predict user correlation of target content messages in a mobile environment
CN200880123555.8A CN101911617B (en) 2007-11-14 2008-11-14 User profiles coupling indicating means in mobile environment and system
KR1020107013116A KR101195640B1 (en) 2007-11-14 2008-11-14 User profile match indication in a mobile environment methods and systems
KR1020107013111A KR101134248B1 (en) 2007-11-14 2008-11-14 Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
PCT/US2008/083667 WO2009065060A1 (en) 2007-11-14 2008-11-14 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
JP2010534237A JP2011507055A (en) 2007-11-14 2008-11-14 Mobile profile method and user profile match display in mobile environment system
KR1020107013102A KR101190446B1 (en) 2007-11-14 2008-11-14 Method and system for message value calculation in a mobile environment
JP2010534245A JP5307153B2 (en) 2007-11-14 2008-11-14 Method and system for message value calculation in a mobile environment
JP2013000190A JP5657712B2 (en) 2007-11-14 2013-01-04 Mobile profile method and user profile match display in mobile environment system
JP2014096346A JP2014194796A (en) 2007-11-14 2014-05-07 Methods and systems for determining geographic user profile to determine suitability of targeted content messages based on the profile

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US98803307P 2007-11-14 2007-11-14
US98804507P 2007-11-14 2007-11-14
US98803707P 2007-11-14 2007-11-14
US98802907P 2007-11-14 2007-11-14
US12/268,914 US20090125517A1 (en) 2007-11-14 2008-11-11 Method and system for keyword correlation in a mobile environment

Publications (1)

Publication Number Publication Date
US20090125517A1 true US20090125517A1 (en) 2009-05-14

Family

ID=40624182

Family Applications (5)

Application Number Title Priority Date Filing Date
US12/268,939 Expired - Fee Related US9203912B2 (en) 2007-11-14 2008-11-11 Method and system for message value calculation in a mobile environment
US12/268,927 Expired - Fee Related US9203911B2 (en) 2007-11-14 2008-11-11 Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
US12/268,945 Active 2032-05-23 US9705998B2 (en) 2007-11-14 2008-11-11 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US12/268,905 Abandoned US20090124241A1 (en) 2007-11-14 2008-11-11 Method and system for user profile match indication in a mobile environment
US12/268,914 Abandoned US20090125517A1 (en) 2007-11-14 2008-11-11 Method and system for keyword correlation in a mobile environment

Family Applications Before (4)

Application Number Title Priority Date Filing Date
US12/268,939 Expired - Fee Related US9203912B2 (en) 2007-11-14 2008-11-11 Method and system for message value calculation in a mobile environment
US12/268,927 Expired - Fee Related US9203911B2 (en) 2007-11-14 2008-11-11 Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
US12/268,945 Active 2032-05-23 US9705998B2 (en) 2007-11-14 2008-11-11 Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US12/268,905 Abandoned US20090124241A1 (en) 2007-11-14 2008-11-11 Method and system for user profile match indication in a mobile environment

Country Status (6)

Country Link
US (5) US9203912B2 (en)
EP (5) EP2225859A1 (en)
JP (6) JP5345631B2 (en)
KR (5) KR101134248B1 (en)
CN (5) CN101911620B (en)
WO (5) WO2009065064A1 (en)

Cited By (78)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080120308A1 (en) * 2006-11-22 2008-05-22 Ronald Martinez Methods, Systems and Apparatus for Delivery of Media
US20090011740A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for providing targeted information based on a user profile in a mobile environment
US20090024452A1 (en) * 2006-11-22 2009-01-22 Ronald Martinez Methods, systems and apparatus for delivery of media
US20090030872A1 (en) * 2007-07-25 2009-01-29 Matthew Brezina Display of Attachment Based Information within a Messaging System
US20090048977A1 (en) * 2007-07-07 2009-02-19 Qualcomm Incorporated User profile generation architecture for targeted content distribution using external processes
US20090124241A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for user profile match indication in a mobile environment
US20090125321A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
US20090150507A1 (en) * 2007-12-07 2009-06-11 Yahoo! Inc. System and method for prioritizing delivery of communications via different communication channels
US20090157834A1 (en) * 2007-12-14 2009-06-18 Qualcomm Incorporated Method and system for multi-level distribution information cache management in a mobile environment
US20090177644A1 (en) * 2008-01-04 2009-07-09 Ronald Martinez Systems and methods of mapping attention
US20090182631A1 (en) * 2008-01-16 2009-07-16 Yahoo! Inc. System and method for word-of-mouth advertising
US20090278738A1 (en) * 2008-05-12 2009-11-12 Qualcomm Incorporated Gps power savings using low power sensors
US20090319329A1 (en) * 2007-07-07 2009-12-24 Qualcomm Incorporated User profile generation architecture for mobile content-message targeting
US20090328087A1 (en) * 2008-06-27 2009-12-31 Yahoo! Inc. System and method for location based media delivery
US20100082593A1 (en) * 2008-09-24 2010-04-01 Yahoo! Inc. System and method for ranking search results using social information
US20100161544A1 (en) * 2008-12-23 2010-06-24 Samsung Electronics Co., Ltd. Context-based interests in computing environments and systems
US20100161381A1 (en) * 2008-12-23 2010-06-24 Samsung Electronics Co., Ltd. Semantics-based interests in computing environments and systems
US20100198604A1 (en) * 2009-01-30 2010-08-05 Samsung Electronics Co., Ltd. Generation of concept relations
US20100299329A1 (en) * 2009-05-20 2010-11-25 Genieo Innovation Ltd. Apparatus and Methods for Providing Answers to Queries Respective of a User Based on User Uniquifiers
WO2011085037A1 (en) 2010-01-05 2011-07-14 Qualcomm Incorporated Method for determining the correlation between a received user profile and a stored user profile
US20110191768A1 (en) * 2010-02-03 2011-08-04 Xobni Corporation Systems and Methods to Identify Users Using an Automated Learning Process
US20110222454A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US8024317B2 (en) 2008-11-18 2011-09-20 Yahoo! Inc. System and method for deriving income from URL based context queries
US8032508B2 (en) 2008-11-18 2011-10-04 Yahoo! Inc. System and method for URL based query for retrieving data related to a context
US8055675B2 (en) 2008-12-05 2011-11-08 Yahoo! Inc. System and method for context based query augmentation
US8060492B2 (en) 2008-11-18 2011-11-15 Yahoo! Inc. System and method for generation of URL based context queries
US8069142B2 (en) 2007-12-06 2011-11-29 Yahoo! Inc. System and method for synchronizing data on a network
US8108778B2 (en) 2008-09-30 2012-01-31 Yahoo! Inc. System and method for context enhanced mapping within a user interface
US20120075264A1 (en) * 2010-09-28 2012-03-29 Kies Jonathan K Apparatus and methods for presenting interaction information
US8150967B2 (en) 2009-03-24 2012-04-03 Yahoo! Inc. System and method for verified presence tracking
US8166016B2 (en) 2008-12-19 2012-04-24 Yahoo! Inc. System and method for automated service recommendations
US8166168B2 (en) 2007-12-17 2012-04-24 Yahoo! Inc. System and method for disambiguating non-unique identifiers using information obtained from disparate communication channels
US20120229340A1 (en) * 2009-12-15 2012-09-13 Paul Henry Systems and Methods for Determining Geographic Location of a Mobile Device
US8271506B2 (en) 2008-03-31 2012-09-18 Yahoo! Inc. System and method for modeling relationships between entities
US8281027B2 (en) 2008-09-19 2012-10-02 Yahoo! Inc. System and method for distributing media related to a location
WO2012141945A1 (en) 2011-04-11 2012-10-18 Microsoft Corporation Adaptive notifications
US8307029B2 (en) 2007-12-10 2012-11-06 Yahoo! Inc. System and method for conditional delivery of messages
US8364611B2 (en) 2009-08-13 2013-01-29 Yahoo! Inc. System and method for precaching information on a mobile device
US8386506B2 (en) 2008-08-21 2013-02-26 Yahoo! Inc. System and method for context enhanced messaging
US20130059609A1 (en) * 2009-02-04 2013-03-07 Google Inc. Mobile Device Battery Management
US8452855B2 (en) 2008-06-27 2013-05-28 Yahoo! Inc. System and method for presentation of media related to a context
US20130151540A1 (en) * 2011-12-08 2013-06-13 Palo Alto Research Center Incorporated Privacy-preserving collaborative filtering
US8538811B2 (en) 2008-03-03 2013-09-17 Yahoo! Inc. Method and apparatus for social network marketing with advocate referral
US8554623B2 (en) 2008-03-03 2013-10-08 Yahoo! Inc. Method and apparatus for social network marketing with consumer referral
US8560390B2 (en) 2008-03-03 2013-10-15 Yahoo! Inc. Method and apparatus for social network marketing with brand referral
US8583668B2 (en) 2008-07-30 2013-11-12 Yahoo! Inc. System and method for context enhanced mapping
US8589486B2 (en) 2008-03-28 2013-11-19 Yahoo! Inc. System and method for addressing communications
US8594702B2 (en) 2006-11-06 2013-11-26 Yahoo! Inc. Context server for associating information based on context
US8671154B2 (en) 2007-12-10 2014-03-11 Yahoo! Inc. System and method for contextual addressing of communications on a network
US8706406B2 (en) 2008-06-27 2014-04-22 Yahoo! Inc. System and method for determination and display of personalized distance
US8745133B2 (en) 2008-03-28 2014-06-03 Yahoo! Inc. System and method for optimizing the storage of data
US8762285B2 (en) 2008-01-06 2014-06-24 Yahoo! Inc. System and method for message clustering
US8769099B2 (en) 2006-12-28 2014-07-01 Yahoo! Inc. Methods and systems for pre-caching information on a mobile computing device
US20140201358A1 (en) * 2013-01-15 2014-07-17 Marvell World Trade Ltd. System and Method for Asynchronous Event Reporting
US8892495B2 (en) 1991-12-23 2014-11-18 Blanding Hovenweep, Llc Adaptive pattern recognition based controller apparatus and method and human-interface therefore
US8914342B2 (en) 2009-08-12 2014-12-16 Yahoo! Inc. Personal data platform
KR20150018474A (en) * 2013-08-08 2015-02-23 큐리온코리아 주식회사 Method, system and non-transitory computer-readable recording medium for extracting semantic keyword
WO2015038899A1 (en) * 2013-09-12 2015-03-19 Upsight, Inc. Systems and methods for predicting user lifetime value using cohorts
US9020938B2 (en) 2010-02-03 2015-04-28 Yahoo! Inc. Providing profile information using servers
WO2015088993A3 (en) * 2013-12-12 2015-08-13 Microsoft Technology Licensing, Llc Predicted travel intent
US9110903B2 (en) 2006-11-22 2015-08-18 Yahoo! Inc. Method, system and apparatus for using user profile electronic device data in media delivery
US9224172B2 (en) 2008-12-02 2015-12-29 Yahoo! Inc. Customizable content for distribution in social networks
US9507778B2 (en) 2006-05-19 2016-11-29 Yahoo! Inc. Summarization of media object collections
US9535563B2 (en) 1999-02-01 2017-01-03 Blanding Hovenweep, Llc Internet appliance system and method
US9600484B2 (en) 2008-09-30 2017-03-21 Excalibur Ip, Llc System and method for reporting and analysis of media consumption data
US9706345B2 (en) 2008-01-04 2017-07-11 Excalibur Ip, Llc Interest mapping system
US9747583B2 (en) 2011-06-30 2017-08-29 Yahoo Holdings, Inc. Presenting entity profile information to a user of a computing device
US9760866B2 (en) 2009-12-15 2017-09-12 Yahoo Holdings, Inc. Systems and methods to provide server side profile information
US9805123B2 (en) 2008-11-18 2017-10-31 Excalibur Ip, Llc System and method for data privacy in URL based context queries
US10165064B2 (en) * 2017-01-11 2018-12-25 Google Llc Data packet transmission optimization of data used for content item selection
US10192200B2 (en) 2012-12-04 2019-01-29 Oath Inc. Classifying a portion of user contact data into local contacts
US10223701B2 (en) 2009-08-06 2019-03-05 Excalibur Ip, Llc System and method for verified monetization of commercial campaigns
US10230803B2 (en) 2008-07-30 2019-03-12 Excalibur Ip, Llc System and method for improved mapping and routing
WO2019016614A3 (en) * 2017-07-14 2019-05-02 Alibaba Group Holding Limited Method and apparatus for displaying search results
CN110113410A (en) * 2019-04-30 2019-08-09 秒针信息技术有限公司 A kind of management method, device, electronic equipment and the storage medium of information push
US10436615B2 (en) 2017-04-24 2019-10-08 Carnegie Mellon University Virtual sensor system
US10791187B2 (en) 2016-04-29 2020-09-29 Beijing Xiaomi Mobile Software Co., Ltd. Information displaying method and apparatus, and storage medium
US11038994B2 (en) * 2016-02-10 2021-06-15 Telefonaktiebolaget Lm Ericsson (Publ) Technique for transport protocol selection and setup of a connection between a client and a server

Families Citing this family (219)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SE0002572D0 (en) 2000-07-07 2000-07-07 Ericsson Telefon Ab L M Communication system
ES2362359T3 (en) * 2005-12-02 2011-07-04 Microsoft Corporation MESSAGE SERVICE.
GB2435565B (en) 2006-08-09 2008-02-20 Cvon Services Oy Messaging system
WO2008049955A1 (en) 2006-10-27 2008-05-02 Cvon Innovations Ltd Method and device for managing subscriber connection
US20100274661A1 (en) * 2006-11-01 2010-10-28 Cvon Innovations Ltd Optimization of advertising campaigns on mobile networks
GB2435730B (en) 2006-11-02 2008-02-20 Cvon Innovations Ltd Interactive communications system
GB2436412A (en) 2006-11-27 2007-09-26 Cvon Innovations Ltd Authentication of network usage for use with message modifying apparatus
US8856289B2 (en) 2006-12-29 2014-10-07 Prodea Systems, Inc. Subscription management of applications and services provided through user premises gateway devices
US11316688B2 (en) 2006-12-29 2022-04-26 Kip Prod P1 Lp Multi-services application gateway and system employing the same
US9602880B2 (en) 2006-12-29 2017-03-21 Kip Prod P1 Lp Display inserts, overlays, and graphical user interfaces for multimedia systems
US9569587B2 (en) 2006-12-29 2017-02-14 Kip Prod Pi Lp Multi-services application gateway and system employing the same
US11783925B2 (en) 2006-12-29 2023-10-10 Kip Prod P1 Lp Multi-services application gateway and system employing the same
US20160277261A9 (en) * 2006-12-29 2016-09-22 Prodea Systems, Inc. Multi-services application gateway and system employing the same
GB2440990B (en) 2007-01-09 2008-08-06 Cvon Innovations Ltd Message scheduling system
GB2445630B (en) 2007-03-12 2008-11-12 Cvon Innovations Ltd Dynamic message allocation system and method
GB2440408B (en) * 2007-05-16 2008-06-25 Cvon Innovations Ltd Method and system for scheduling of messages
US8935718B2 (en) 2007-05-22 2015-01-13 Apple Inc. Advertising management method and system
GB2450144A (en) 2007-06-14 2008-12-17 Cvon Innovations Ltd System for managing the delivery of messages
US9177323B2 (en) 2007-08-28 2015-11-03 Causam Energy, Inc. Systems and methods for determining and utilizing customer energy profiles for load control for individual structures, devices, and aggregation of same
US8890505B2 (en) 2007-08-28 2014-11-18 Causam Energy, Inc. System and method for estimating and providing dispatchable operating reserve energy capacity through use of active load management
US10295969B2 (en) 2007-08-28 2019-05-21 Causam Energy, Inc. System and method for generating and providing dispatchable operating reserve energy capacity through use of active load management
US9130402B2 (en) 2007-08-28 2015-09-08 Causam Energy, Inc. System and method for generating and providing dispatchable operating reserve energy capacity through use of active load management
US8806239B2 (en) 2007-08-28 2014-08-12 Causam Energy, Inc. System, method, and apparatus for actively managing consumption of electric power supplied by one or more electric power grid operators
US8805552B2 (en) 2007-08-28 2014-08-12 Causam Energy, Inc. Method and apparatus for actively managing consumption of electric power over an electric power grid
GB2452789A (en) 2007-09-05 2009-03-18 Cvon Innovations Ltd Selecting information content for transmission by identifying a keyword in a previous message
GB2453810A (en) 2007-10-15 2009-04-22 Cvon Innovations Ltd System, Method and Computer Program for Modifying Communications by Insertion of a Targeted Media Content or Advertisement
KR101112204B1 (en) * 2007-12-04 2012-03-09 한국전자통신연구원 Mobile Advertisement Method
US8965786B1 (en) * 2008-04-18 2015-02-24 Google Inc. User-based ad ranking
US20090298483A1 (en) * 2008-06-02 2009-12-03 Motorola, Inc. Method and apparatus for selecting advertisements and determining constraints for presenting the advertisements on mobile communication devices
CN101360098B (en) * 2008-08-29 2012-02-15 腾讯科技(北京)有限公司 Customer behavior attribute determining method, apparatus, system and advertisement releasing method and system
US20100076846A1 (en) * 2008-09-25 2010-03-25 Yahoo! Inc. Interest manager
US8738436B2 (en) * 2008-09-30 2014-05-27 Yahoo! Inc. Click through rate prediction system and method
US20130318167A1 (en) * 2009-05-20 2013-11-28 Aaron SEREBOFF Method and apparatus for providing exchange of profile information
EP2271036B1 (en) 2009-06-22 2013-01-09 Semiocast Method, system and architecture for delivering messages in a network to automatically increase a signal-to-noise ratio of user interests
WO2010151194A1 (en) * 2009-06-26 2010-12-29 Telefonaktiebolaget L M Ericsson (Publ) Method and arrangement in a communication network
KR101169840B1 (en) * 2009-08-05 2012-07-30 삼성전자주식회사 System and method for providing of personalized mobile advertising
US9529864B2 (en) 2009-08-28 2016-12-27 Microsoft Technology Licensing, Llc Data mining electronic communications
GB2473197A (en) 2009-09-02 2011-03-09 Nds Ltd Advert selection using a decision tree
US8510769B2 (en) 2009-09-14 2013-08-13 Tivo Inc. Media content finger print system
US9124642B2 (en) * 2009-10-16 2015-09-01 Qualcomm Incorporated Adaptively streaming multimedia
US8682145B2 (en) 2009-12-04 2014-03-25 Tivo Inc. Recording system based on multimedia content fingerprints
US8751743B2 (en) 2010-03-15 2014-06-10 Howard University Apparatus and method for context-aware mobile data management
US20110238485A1 (en) * 2010-03-26 2011-09-29 Nokia Corporation Method and apparatus for utilizing confidence levels to serve advertisements
RU2573777C2 (en) 2010-04-30 2016-01-27 НАУ ТЕКНОЛОДЖИЗ (Ай Пи) ЛИМИТЕД Content management apparatus
US8898217B2 (en) 2010-05-06 2014-11-25 Apple Inc. Content delivery based on user terminal events
US20110282964A1 (en) * 2010-05-13 2011-11-17 Qualcomm Incorporated Delivery of targeted content related to a learned and predicted future behavior based on spatial, temporal, and user attributes and behavioral constraints
US8504419B2 (en) 2010-05-28 2013-08-06 Apple Inc. Network-based targeted content delivery based on queue adjustment factors calculated using the weighted combination of overall rank, context, and covariance scores for an invitational content item
US9210528B2 (en) 2010-07-21 2015-12-08 Tksn Holdings, Llc System and method for control and management of resources for consumers of information
US9232046B2 (en) 2010-07-21 2016-01-05 Tksn Holdings, Llc System and method for controlling mobile services using sensor information
US20120021770A1 (en) 2010-07-21 2012-01-26 Naqvi Shamim A System and method for control and management of resources for consumers of information
US8510658B2 (en) 2010-08-11 2013-08-13 Apple Inc. Population segmentation
US9171311B2 (en) 2010-08-31 2015-10-27 Microsoft Technology Licensing, Llc Maintaining targetable user inventory for digital advertising
US8510309B2 (en) 2010-08-31 2013-08-13 Apple Inc. Selection and delivery of invitational content based on prediction of user interest
US8983978B2 (en) 2010-08-31 2015-03-17 Apple Inc. Location-intention context for content delivery
US8996624B2 (en) 2010-09-15 2015-03-31 At&T Intellectual Property I, L.P. Managing presence in communications systems
US20120089983A1 (en) * 2010-10-11 2012-04-12 Tata Consultancy Services Limited Assessing process deployment
US8499048B2 (en) 2010-10-27 2013-07-30 Facebook, Inc. Indexing and organizing messages in a messaging system using social network information
US8706824B2 (en) 2011-08-08 2014-04-22 Facebook, Inc. Rescinding messages in a messaging system with multiple messaging channels
US8880627B2 (en) 2011-08-08 2014-11-04 Facebook, Inc. Providing transparency in a messaging system with multiple messaging channels
US9203796B2 (en) 2010-11-12 2015-12-01 Facebook, Inc. Messaging system with multiple messaging channels
AU2011326513B2 (en) * 2010-11-12 2016-03-17 Facebook, Inc. Messaging system with multiple messaging channels
US8744979B2 (en) * 2010-12-06 2014-06-03 Microsoft Corporation Electronic communications triage using recipient's historical behavioral and feedback
US8626587B2 (en) * 2010-12-10 2014-01-07 Verizon Patent And Licensing Inc. Artificial intelligence-based recommender and self-provisioner
KR101051804B1 (en) 2010-12-16 2011-07-25 전자부품연구원 System of targeting data service for web-based media contents
CA2824631A1 (en) 2011-01-03 2012-07-12 Wellness & Prevention, Inc. Method and system for automated team support message delivery
US20120173639A1 (en) * 2011-01-03 2012-07-05 Thomas Walsh Method and system for personalized message delivery
US8849990B2 (en) * 2011-02-03 2014-09-30 Disney Enterprises, Inc. Optimized video streaming to client devices
EP2521328A3 (en) * 2011-02-17 2013-02-20 Prolifiq Software Inc. Dedicated message channel
US8682895B1 (en) * 2011-03-31 2014-03-25 Twitter, Inc. Content resonance
KR20120117044A (en) * 2011-04-14 2012-10-24 조진형 Bidirectional digital advertisement service system and that of supply method
US20120272156A1 (en) * 2011-04-22 2012-10-25 Kerger Kameron N Leveraging context to present content on a communication device
US9002957B2 (en) * 2011-04-27 2015-04-07 Verizon Patent And Licensing Inc. Profile message communications
US8671185B2 (en) * 2011-05-03 2014-03-11 Facebook, Inc. Data transmission between devices based on bandwidth availability
US20120323698A1 (en) * 2011-06-14 2012-12-20 Disman William S Interface for Online Advertising
US8498627B2 (en) 2011-09-15 2013-07-30 Digimarc Corporation Intuitive computing methods and systems
US10467677B2 (en) * 2011-09-28 2019-11-05 Nara Logics, Inc. Systems and methods for providing recommendations based on collaborative and/or content-based nodal interrelationships
US9225173B2 (en) 2011-09-28 2015-12-29 Causam Energy, Inc. Systems and methods for microgrid power generation and management
CN102411753A (en) * 2011-09-28 2012-04-11 中兴通讯股份有限公司 Method for realizing audience division based on NFC, server thereof and system thereof
US8751036B2 (en) 2011-09-28 2014-06-10 Causam Energy, Inc. Systems and methods for microgrid power generation management with selective disconnect
US8862279B2 (en) 2011-09-28 2014-10-14 Causam Energy, Inc. Systems and methods for optimizing microgrid power generation and management with predictive modeling
US11727249B2 (en) 2011-09-28 2023-08-15 Nara Logics, Inc. Methods for constructing and applying synaptic networks
US10091322B2 (en) 2011-10-18 2018-10-02 Qualcomm Incorporated Method and apparatus for improving a user experience or device performance using an enriched user profile
US9767465B2 (en) * 2011-10-28 2017-09-19 Excalibur Ip, Llc Methods and systems for facilitating caching of advertisements
US8954100B2 (en) 2011-11-04 2015-02-10 Facebook, Inc. Server-side rate-limiting algorithms for piggybacking social updates for mobile devices
US8989818B2 (en) 2011-11-04 2015-03-24 Facebook, Inc. Device actions based on device power
US20130125061A1 (en) 2011-11-11 2013-05-16 Jongwoo LEE Efficient Navigation Of Hierarchical Data Displayed In A Graphical User Interface
US8869041B2 (en) 2011-11-11 2014-10-21 Apollo Education Group, Inc. Dynamic and local management of hierarchical discussion thread data
US8966404B2 (en) 2011-11-11 2015-02-24 Apollo Education Group, Inc. Hierarchy-indicating graphical user interface for discussion threads
WO2013077804A2 (en) * 2011-11-24 2013-05-30 Vivalect Ab Advertisement delivery method
US11290912B2 (en) * 2011-12-14 2022-03-29 Seven Networks, Llc Mobile device configured for operating in a power save mode and a traffic optimization mode and related method
US10038927B2 (en) * 2011-12-22 2018-07-31 Cisco Technology, Inc. Out-of-band signaling and device-based content control
US8797899B2 (en) * 2011-12-22 2014-08-05 Qualcomm Incorporated System and method for probabilistic WLAN positioning
EP2815329A2 (en) * 2012-02-17 2014-12-24 Danielli, Alberto Method for managing via web data related to an event and/or a person and/or an organization
US10157388B2 (en) * 2012-02-22 2018-12-18 Oracle International Corporation Generating promotions to a targeted audience
US11328325B2 (en) * 2012-03-23 2022-05-10 Secureads, Inc. Method and/or system for user authentication with targeted electronic advertising content through personal communication devices
RU2510982C2 (en) * 2012-04-06 2014-04-10 Закрытое акционерное общество "Лаборатория Касперского" User evaluation system and method for message filtering
US8996997B2 (en) 2012-04-18 2015-03-31 Sap Se Flip-through format to view notification and related items
EP2845402B1 (en) * 2012-04-30 2016-06-08 Hewlett-Packard Development Company, L.P. Controlling behavior of mobile devices
US9525587B2 (en) 2012-05-17 2016-12-20 International Business Machines Corporation Updating web resources
US9461471B2 (en) 2012-06-20 2016-10-04 Causam Energy, Inc System and methods for actively managing electric power over an electric power grid and providing revenue grade date usable for settlement
US9465398B2 (en) 2012-06-20 2016-10-11 Causam Energy, Inc. System and methods for actively managing electric power over an electric power grid
US9207698B2 (en) 2012-06-20 2015-12-08 Causam Energy, Inc. Method and apparatus for actively managing electric power over an electric power grid
WO2013192538A2 (en) * 2012-06-22 2013-12-27 Jiwire, Inc. Location graph based derivation of attributes
US9141504B2 (en) 2012-06-28 2015-09-22 Apple Inc. Presenting status data received from multiple devices
US9563215B2 (en) 2012-07-14 2017-02-07 Causam Energy, Inc. Method and apparatus for actively managing electric power supply for an electric power grid
TWI574218B (en) * 2012-07-19 2017-03-11 菲絲博克公司 Customizing content delivery from a brand page to a user in a social networking environment
EP2877935A4 (en) * 2012-07-25 2016-01-20 Aro Inc Using mobile device data to create a storyline, model user routine and personality, and create customized recommendation agents
US10475138B2 (en) 2015-09-23 2019-11-12 Causam Energy, Inc. Systems and methods for advanced energy network
US9513648B2 (en) 2012-07-31 2016-12-06 Causam Energy, Inc. System, method, and apparatus for electric power grid and network management of grid elements
US8849715B2 (en) 2012-10-24 2014-09-30 Causam Energy, Inc. System, method, and apparatus for settlement for participation in an electric power grid
US10861112B2 (en) 2012-07-31 2020-12-08 Causam Energy, Inc. Systems and methods for advanced energy settlements, network-based messaging, and applications supporting the same on a blockchain platform
US8983669B2 (en) 2012-07-31 2015-03-17 Causam Energy, Inc. System, method, and data packets for messaging for electric power grid elements over a secure internet protocol network
CN103684969A (en) * 2012-08-31 2014-03-26 国际商业机器公司 Message handling method and message handling system
WO2014037937A2 (en) * 2012-09-06 2014-03-13 Beyond Verbal Communication Ltd System and method for selection of data according to measurement of physiological parameters
US20140074959A1 (en) * 2012-09-10 2014-03-13 Apple Inc. Client side media station generation
US20140089092A1 (en) * 2012-09-27 2014-03-27 Livingsocial, Inc. Client-Based Deal Filtering and Display
US9654591B2 (en) * 2012-10-01 2017-05-16 Facebook, Inc. Mobile device-related measures of affinity
WO2014053192A1 (en) * 2012-10-05 2014-04-10 Telefonaktiebolaget L M Ericsson (Publ) Method and apparatus for ranking users within a network
US9721263B2 (en) * 2012-10-26 2017-08-01 Nbcuniversal Media, Llc Continuously evolving symmetrical object profiles for online advertisement targeting
US9372811B2 (en) * 2012-12-13 2016-06-21 Arm Limited Retention priority based cache replacement policy
CN103927162B (en) * 2013-01-15 2018-09-21 马维尔国际贸易有限公司 system and method for asynchronous event report
US9632797B2 (en) * 2013-01-31 2017-04-25 Hewlett Packard Enterprise Development Lp Updating a commit list to indicate data to be written to a firmware interface variable repository
US9753965B2 (en) 2013-03-15 2017-09-05 Factual Inc. Apparatus, systems, and methods for providing location information
US9558508B2 (en) * 2013-03-15 2017-01-31 Microsoft Technology Licensing, Llc Energy-efficient mobile advertising
CN105229684B (en) * 2013-03-15 2021-02-19 布莱恩·麦克法登 System for controlling and optimizing information distribution between users in information exchange
US10187520B2 (en) 2013-04-24 2019-01-22 Samsung Electronics Co., Ltd. Terminal device and content displaying method thereof, server and controlling method thereof
CN104125333A (en) * 2013-04-24 2014-10-29 三星电子株式会社 Terminal device and content displaying method thereof, server and controlling method thereof
US9871883B2 (en) * 2013-05-31 2018-01-16 Microsoft Technology Licensing, Llc Opportunity events
US20140372216A1 (en) * 2013-06-13 2014-12-18 Microsoft Corporation Contextual mobile application advertisements
US9210132B2 (en) * 2013-06-28 2015-12-08 Cellco Partnership Protecting subscriber information from third parties
JP5959745B2 (en) * 2013-06-28 2016-08-02 楽天株式会社 Advertisement system, advertisement processing device
US9282066B2 (en) 2013-07-18 2016-03-08 International Business Machines Corporation Targeted message response
CA2921622A1 (en) * 2013-08-19 2015-02-26 Monster Worldwide, Inc. Sourcing abound candidates apparatuses, methods and systems
US11556808B1 (en) * 2013-08-29 2023-01-17 Ivanti, Inc. Content delivery optimization
US11100524B1 (en) 2013-12-23 2021-08-24 Massachusetts Mutual Life Insurance Company Next product purchase and lapse predicting tool
US11062337B1 (en) 2013-12-23 2021-07-13 Massachusetts Mutual Life Insurance Company Next product purchase and lapse predicting tool
US11062378B1 (en) 2013-12-23 2021-07-13 Massachusetts Mutual Life Insurance Company Next product purchase and lapse predicting tool
US11831794B1 (en) 2013-12-30 2023-11-28 Massachusetts Mutual Life Insurance Company System and method for managing routing of leads
US11743389B1 (en) 2013-12-30 2023-08-29 Massachusetts Mutual Life Insurance Company System and method for managing routing of customer calls
US11151486B1 (en) 2013-12-30 2021-10-19 Massachusetts Mutual Life Insurance Company System and method for managing routing of leads
US11509771B1 (en) 2013-12-30 2022-11-22 Massachusetts Mutual Life Insurance Company System and method for managing routing of customer calls
US10394834B1 (en) 2013-12-31 2019-08-27 Massachusetts Mutual Life Insurance Company Methods and systems for ranking leads based on given characteristics
US9210207B2 (en) * 2014-02-13 2015-12-08 Ericsson Ab Time-sensitive content manipulation in adaptive streaming buffer
WO2015130983A1 (en) * 2014-02-26 2015-09-03 Vertical Computer Systems, Inc. System and method for distributed advertising
US9420086B2 (en) * 2014-03-05 2016-08-16 Honda Motor Co., Ltd. Information terminal
US10884991B1 (en) * 2014-03-14 2021-01-05 Jpmorgan Chase Bank, N.A. Data request analysis and fulfillment system and method
JP6327950B2 (en) * 2014-05-28 2018-05-23 ヤフー株式会社 Predicted value calculation device, predicted value calculation method, and predicted value calculation program
US9552587B2 (en) 2014-07-11 2017-01-24 Sensoriant, Inc. System and method for mediating representations with respect to preferences of a party not located in the environment
US10390289B2 (en) 2014-07-11 2019-08-20 Sensoriant, Inc. Systems and methods for mediating representations allowing control of devices located in an environment having broadcasting devices
US9853950B2 (en) 2014-08-13 2017-12-26 Oath Inc. Systems and methods for protecting internet advertising data
CN105491092B (en) * 2014-09-18 2020-05-26 腾讯科技(深圳)有限公司 Message pushing method and device
US10068256B2 (en) * 2014-10-08 2018-09-04 Microsoft Technology Licensing, Llc User directed information collections
US10116560B2 (en) 2014-10-20 2018-10-30 Causam Energy, Inc. Systems, methods, and apparatus for communicating messages of distributed private networks over multiple public communication networks
US9996575B2 (en) 2014-10-30 2018-06-12 Twitter, Inc. Automated social message stream population
US10325220B2 (en) 2014-11-17 2019-06-18 Oath Inc. System and method for large-scale multi-label learning using incomplete label assignments
US20160335272A1 (en) * 2014-12-13 2016-11-17 Velvet Ropes, Inc. Methods and systems for rating celebrities for generating a digital celebrity map tour guide
US10327094B2 (en) 2016-06-07 2019-06-18 NinthDecimal, Inc. Systems and methods to track locations visited by mobile devices and determine neighbors of and distances among locations
US11410225B2 (en) * 2015-01-13 2022-08-09 State Farm Mutual Automobile Insurance Company System and method for a fast rental application
US9661386B2 (en) * 2015-02-11 2017-05-23 Google Inc. Methods, systems, and media for presenting a suggestion to watch videos
US10379497B2 (en) 2015-03-07 2019-08-13 Apple Inc. Obtaining and displaying time-related data on an electronic watch
US9825962B2 (en) * 2015-03-27 2017-11-21 Accenture Global Services Limited Configurable sharing of user information
US10175866B2 (en) 2015-06-05 2019-01-08 Apple Inc. Providing complications on an electronic watch
US10572571B2 (en) 2015-06-05 2020-02-25 Apple Inc. API for specifying display of complication on an electronic watch
US11327640B2 (en) 2015-06-05 2022-05-10 Apple Inc. Providing complications on an electronic device
CN105046512A (en) * 2015-06-19 2015-11-11 长沙待霁电子科技有限公司 Intelligent positioning advertisement method
CN105046513A (en) * 2015-06-19 2015-11-11 长沙待霁电子科技有限公司 Vehicle-mounted regionalization intelligence positioning advertisement method
US20170011049A1 (en) * 2015-07-09 2017-01-12 Longsand Limited Attribute analyzer for data backup
US9807198B2 (en) 2015-08-20 2017-10-31 Google Inc. Methods and systems of identifying a device using strong component conflict detection
WO2017053707A1 (en) 2015-09-23 2017-03-30 Sensoriant, Inc. Method and system for using device states and user preferences to create user-friendly environments
JP6062014B1 (en) * 2015-09-29 2017-01-18 Line株式会社 Information processing apparatus, control method, and program
CN105245609A (en) * 2015-10-23 2016-01-13 小米科技有限责任公司 Information pushing method, device, equipment and system
EP3182738B1 (en) * 2015-12-16 2018-12-05 Snips Method and means for triggering at least one action based on geolocation and user information, places and user habits
KR101694727B1 (en) * 2015-12-28 2017-01-10 주식회사 파수닷컴 Method and apparatus for providing note by using calculating degree of association based on artificial intelligence
CN105678587B (en) * 2016-01-12 2020-11-24 腾讯科技(深圳)有限公司 Recommendation feature determination method, information recommendation method and device
EP3405880A4 (en) * 2016-01-22 2019-06-26 eBay Inc. Context identification for content generation
US9848061B1 (en) 2016-10-28 2017-12-19 Vignet Incorporated System and method for rules engine that dynamically adapts application behavior
US10178171B2 (en) 2016-04-21 2019-01-08 Samsung Electronics Company, Ltd. Content management system for distribution of content
US10523635B2 (en) * 2016-06-17 2019-12-31 Assured Information Security, Inc. Filtering outbound network traffic
US10104417B2 (en) 2016-07-26 2018-10-16 At&T Mobility Ii Llc Method and apparatus for sponsored messaging
CN107665225B (en) * 2016-07-29 2022-01-28 北京京东尚科信息技术有限公司 Information pushing method and device
CN107872494B (en) * 2016-09-28 2020-12-08 腾讯科技(深圳)有限公司 Message pushing method and device
US10229193B2 (en) * 2016-10-03 2019-03-12 Sap Se Collecting event related tweets
US10542148B1 (en) 2016-10-12 2020-01-21 Massachusetts Mutual Life Insurance Company System and method for automatically assigning a customer call to an agent
KR102585230B1 (en) * 2016-11-15 2023-10-05 삼성전자주식회사 Device and method for providing notification message for call request
GB201620476D0 (en) * 2016-12-02 2017-01-18 Omarco Network Solutions Ltd Computer-implemented method of predicting performance data
CN106600069B (en) * 2016-12-20 2020-08-18 西南石油大学 Method and system for predicting microblog forwarding based on microblog subject label
US10616153B2 (en) * 2016-12-30 2020-04-07 Logmein, Inc. Real-time communications system with intelligent presence indication
US10348820B2 (en) * 2017-01-20 2019-07-09 Facebook, Inc. Peer-to-peer content distribution
US10101971B1 (en) 2017-03-29 2018-10-16 International Business Machines Corporation Hardware device based software verification
US10685294B2 (en) 2017-03-29 2020-06-16 International Business Machines Corporation Hardware device based software selection
US10042614B1 (en) * 2017-03-29 2018-08-07 International Business Machines Corporation Hardware device based software generation
IL252041B (en) * 2017-04-30 2020-09-30 Verint Systems Ltd System and method for tracking users of computer applications
WO2018204672A1 (en) * 2017-05-03 2018-11-08 Oshea Timothy James Learning radio signals using radio signal transformers
US11176461B1 (en) 2017-08-29 2021-11-16 Massachusetts Mutual Life Insurance Company System and method for managing routing of customer calls to agents
US10257357B1 (en) 2017-08-29 2019-04-09 Massachusetts Mutual Life Insurance Company System and method for managing routing of customer calls to agents
JP7013178B2 (en) * 2017-09-08 2022-01-31 株式会社日立製作所 Data analysis system, data analysis method, and data analysis program
US11048766B1 (en) * 2018-06-26 2021-06-29 Facebook, Inc. Audience-centric event analysis
CN109067842B (en) * 2018-07-06 2020-06-26 电子科技大学 Calculation task unloading method facing Internet of vehicles
CN109040300B (en) * 2018-09-04 2021-05-14 航天信息股份有限公司 Method, device and storage medium for pushing messages
WO2020159917A1 (en) 2019-01-28 2020-08-06 Pindrop Security, Inc. Unsupervised keyword spotting and word discovery for fraud analytics
CN111506522B (en) * 2019-01-31 2023-04-18 阿里巴巴集团控股有限公司 Data processing apparatus and method
CN109873869B (en) * 2019-03-05 2021-08-24 东南大学 Edge caching method based on reinforcement learning in fog wireless access network
US10862854B2 (en) * 2019-05-07 2020-12-08 Bitdefender IPR Management Ltd. Systems and methods for using DNS messages to selectively collect computer forensic data
US20210004481A1 (en) * 2019-07-05 2021-01-07 Google Llc Systems and methods for privacy preserving determination of intersections of sets of user identifiers
CN110365848B (en) * 2019-07-26 2021-04-13 维沃移动通信有限公司 Message display method and device
US11263667B1 (en) * 2019-07-31 2022-03-01 Meta Platforms, Inc. Scoring of content items having a messaging application as a landing page
CN112306558A (en) * 2019-08-01 2021-02-02 杭州中天微系统有限公司 Processing unit, processor, processing system, electronic device, and processing method
US11803917B1 (en) 2019-10-16 2023-10-31 Massachusetts Mutual Life Insurance Company Dynamic valuation systems and methods
TWI723626B (en) * 2019-11-12 2021-04-01 國立中山大學 Privacy-preserving predicting method, electrical device and computer program product
CN111241225B (en) * 2020-01-10 2023-08-08 北京百度网讯科技有限公司 Method, device, equipment and storage medium for judging change of resident area
EP3902206B1 (en) * 2020-04-21 2022-02-16 TTTech Computertechnik Aktiengesellschaft Fault tolerant distribution unit and method for providing fault tolerant global time
US11500940B2 (en) 2020-08-13 2022-11-15 International Business Machines Corporation Expanding or abridging content based on user device activity
JPWO2022065453A1 (en) * 2020-09-24 2022-03-31
US11875198B2 (en) * 2021-03-22 2024-01-16 EMC IP Holding Company LLC Synchronization object issue detection using object type queues and associated monitor threads in a storage system
US20220335244A1 (en) * 2021-04-19 2022-10-20 Microsoft Technology Licensing, Llc Automatic profile picture updates
KR20220149211A (en) * 2021-04-30 2022-11-08 에이케이시스 주식회사 Mapping profile provide system and method for providing mapping profile
WO2023018895A1 (en) * 2021-08-11 2023-02-16 Edge AI, LLC Body or car mounted camera system
CN114006879B (en) * 2021-10-28 2023-04-07 平安普惠企业管理有限公司 Method for outputting prompt message based on multi-person session group and related equipment
US20230236978A1 (en) * 2022-01-26 2023-07-27 Salesforce.Com, Inc. Progressive caching of filter rules

Citations (97)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5754939A (en) * 1994-11-29 1998-05-19 Herz; Frederick S. M. System for generation of user profiles for a system for customized electronic identification of desirable objects
US6177931B1 (en) * 1996-12-19 2001-01-23 Index Systems, Inc. Systems and methods for displaying and recording control interface with television programs, video, advertising information and program scheduling information
US6202058B1 (en) * 1994-04-25 2001-03-13 Apple Computer, Inc. System for ranking the relevance of information objects accessed by computer users
US20020003162A1 (en) * 2000-04-17 2002-01-10 Ferber John B. Apparatus and method for delivery of targeted marketing to automated service machines
US20020010625A1 (en) * 1998-09-18 2002-01-24 Smith Brent R. Content personalization based on actions performed during a current browsing session
US20020032771A1 (en) * 2000-07-20 2002-03-14 Trond Gledje Event-based advertisements
US20020046084A1 (en) * 1999-10-08 2002-04-18 Scott A. Steele Remotely configurable multimedia entertainment and information system with location based advertising
US20020062251A1 (en) * 2000-09-29 2002-05-23 Rajan Anandan System and method for wireless consumer communications
US20020069105A1 (en) * 1999-12-02 2002-06-06 Do Rosario Botelho Alfredo Agnelo Judas Sebastiao Data processing system for targeted content
US6411807B1 (en) * 1996-02-05 2002-06-25 At&T Wireless Service, Inc. Roaming authorization system
US20030003929A1 (en) * 2001-03-29 2003-01-02 International Business Machines Corporation Method and system for schedule based advertising on a mobile phone
US6507279B2 (en) * 2001-06-06 2003-01-14 Sensormatic Electronics Corporation Complete integrated self-checkout system and method
US6510318B1 (en) * 1998-07-28 2003-01-21 Nec Corporation Method for location registration of mobile stations in a mobile communications system
US20030023489A1 (en) * 2001-06-14 2003-01-30 Mcguire Myles P. Method and system for providing network based target advertising
US6526440B1 (en) * 2001-01-30 2003-02-25 Google, Inc. Ranking search results by reranking the results based on local inter-connectivity
US20030040332A1 (en) * 1996-09-05 2003-02-27 Jerome Swartz System for digital radio communication between a wireless LAN and a PBX
US20030055729A1 (en) * 1999-11-10 2003-03-20 Bezos Jeffrey P. Method and system for allocating display space
US6571279B1 (en) * 1997-12-05 2003-05-27 Pinpoint Incorporated Location enhanced information delivery system
US20030110080A1 (en) * 2000-04-26 2003-06-12 Yuzi Tsutani Advertisement distribution determining/optimizing method
US6677894B2 (en) * 1998-04-28 2004-01-13 Snaptrack, Inc Method and apparatus for providing location-based information via a computer network
US20040049537A1 (en) * 2000-11-20 2004-03-11 Titmuss Richard J Method of managing resources
US20040093418A1 (en) * 2002-11-13 2004-05-13 Jukka Tuomi Update of subscriber profiles in a communication system
US6738678B1 (en) * 1998-01-15 2004-05-18 Krishna Asur Bharat Method for ranking hyperlinked pages using content and connectivity analysis
US6847959B1 (en) * 2000-01-05 2005-01-25 Apple Computer, Inc. Universal interface for retrieval of information in a computer system
US20050063365A1 (en) * 2003-07-11 2005-03-24 Boban Mathew System and method for multi-tiered rule filtering
US6889224B2 (en) * 2001-05-16 2005-05-03 International Business Machines Corporation Method for storing, accessing embedded web pages during manufacturing phase on personal digital device
US6895387B1 (en) * 1999-10-29 2005-05-17 Networks Associates Technology, Inc. Dynamic marketing based on client computer configurations
US20050120003A1 (en) * 2003-10-08 2005-06-02 Drury William J. Method for maintaining a record of searches and results
US6912398B1 (en) * 2000-04-10 2005-06-28 David Domnitz Apparatus and method for delivering information to an individual based on location and/or time
US20050149395A1 (en) * 2003-10-29 2005-07-07 Kontera Technologies, Inc. System and method for real-time web page context analysis for the real-time insertion of textual markup objects and dynamic content
US20060008918A1 (en) * 2002-07-18 2006-01-12 Probert Christopher S J Detection of disease by analysis of emissions
US20060041472A1 (en) * 2004-08-23 2006-02-23 Lukose Rajan M Systems and methods of interfacing an advertisement with a message presentation client
US20060041638A1 (en) * 2004-08-23 2006-02-23 Ianywhere Solutions, Inc. Method, system, and computer program product for offline advertisement servicing and cycling
US20060039303A1 (en) * 2004-08-18 2006-02-23 Howard Singer Method and apparatus for wirelessly sharing a file using an application-level connection
US20060053077A1 (en) * 1999-12-09 2006-03-09 International Business Machines Corporation Digital content distribution using web broadcasting services
US20060059183A1 (en) * 2004-09-16 2006-03-16 Pearson Malcolm E Securely publishing user profile information across a public insecure infrastructure
US20060064346A1 (en) * 2004-08-31 2006-03-23 Qualcomm Incorporated Location based service (LBS) system and method for targeted advertising
US20060064386A1 (en) * 2004-09-20 2006-03-23 Aaron Marking Media on demand via peering
US20060089138A1 (en) * 2004-10-26 2006-04-27 Smith Brian K Method of scanning for beacon transmissions in WLAN
US20060089128A1 (en) * 2001-12-19 2006-04-27 Smith Alan A Method of an apparatus for handling messages in a mobile communications enviroment
US20060129931A1 (en) * 2004-12-10 2006-06-15 Microsoft Corporation Integrated client help viewer for internet-based and local help content
US7065525B1 (en) * 1999-06-30 2006-06-20 Denso Corporation Information service system for providing terminal users with terminal user specific information
US20060136742A1 (en) * 2000-12-27 2006-06-22 Giobbi John J Personal digital key and receiver/decoder circuit system and method
US7069319B2 (en) * 2000-06-30 2006-06-27 Bellsouth Intellectual Property Corporation Anonymous location service for wireless networks
US7069259B2 (en) * 2002-06-28 2006-06-27 Microsoft Corporation Multi-attribute specification of preferences about people, priorities and privacy for guiding messaging and communications
US20070005419A1 (en) * 2005-06-30 2007-01-04 Microsoft Corporation Recommending location and services via geospatial collaborative filtering
US20070022375A1 (en) * 2000-10-19 2007-01-25 David Walker Apparatus, system, and method for an electronic payment system
US20070022098A1 (en) * 2005-07-25 2007-01-25 Dale Malik Systems and methods for automatically updating annotations and marked content of an information search
US20070037610A1 (en) * 2000-08-29 2007-02-15 Logan James D Methods and apparatus for conserving battery power in a cellular or portable telephone
US20070088603A1 (en) * 2005-10-13 2007-04-19 Jouppi Norman P Method and system for targeted data delivery using weight-based scoring
US7222101B2 (en) * 2001-02-26 2007-05-22 American Express Travel Related Services Company, Inc. System and method for securing data through a PDA portal
US20070255690A1 (en) * 2006-04-28 2007-11-01 Chi-Chao Chang System and method for forecasting the performance of advertisements
US20080004952A1 (en) * 2006-06-30 2008-01-03 Nokia Corporation Advertising Middleware
US20080010144A1 (en) * 2006-06-27 2008-01-10 Adchemy, Inc. System and method for generating target bids for advertisement group keywords
US7330824B1 (en) * 2000-02-25 2008-02-12 Navic Systems, Inc. Method and system for content profiling and activation
US20080060000A1 (en) * 2006-08-31 2008-03-06 Francois-Xavier Drouet Personalized advertising in mobile television
US20080077502A1 (en) * 2001-02-17 2008-03-27 Ttb Technologies, Llc Electronic advertising device and method of using the same
US20080082417A1 (en) * 2006-07-31 2008-04-03 Publicover Mark W Advertising and fulfillment system
US20080090513A1 (en) * 2006-01-06 2008-04-17 Qualcomm Incorporated Apparatus and methods of selective collection and selective presentation of content
US20080092171A1 (en) * 2006-10-03 2008-04-17 Verizon Data Services Inc. Control tools for media content access systems and methods
US20080092168A1 (en) * 1999-03-29 2008-04-17 Logan James D Audio and video program recording, editing and playback systems using metadata
US20080091796A1 (en) * 2006-09-29 2008-04-17 Guy Story Methods and apparatus for customized content delivery
US7363035B2 (en) * 2002-02-07 2008-04-22 Qualcomm Incorporated Method and apparatus for providing content to a mobile terminal
US20080098420A1 (en) * 2006-10-19 2008-04-24 Roundbox, Inc. Distribution and display of advertising for devices in a network
US20080103971A1 (en) * 2006-10-31 2008-05-01 Rajan Mathew Lukose Method and system for tracking conversions in a system for targeted data delivery
US7370073B2 (en) * 2000-11-28 2008-05-06 Navic Systems, Inc. Using viewership profiles for targeted promotion deployment
US20080109376A1 (en) * 2006-10-30 2008-05-08 Maxlinear, Inc. Targeted advertisement in the digital television environment
US20080248815A1 (en) * 2007-04-08 2008-10-09 James David Busch Systems and Methods to Target Predictive Location Based Content and Track Conversions
US20090011744A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for delivery of targeted information based on a user profile in a mobile communication device
US20090044246A1 (en) * 2007-02-01 2009-02-12 Patrick Sheehan Targeting content based on location
US20090049090A1 (en) * 2007-08-13 2009-02-19 Research In Motion Limited System and method for facilitating targeted mobile advertisement
US20090048977A1 (en) * 2007-07-07 2009-02-19 Qualcomm Incorporated User profile generation architecture for targeted content distribution using external processes
US20090061884A1 (en) * 2007-06-20 2009-03-05 Rajan Rajeev D Dynamic electronic coupon for a mobile environment
US20090070700A1 (en) * 2007-09-07 2009-03-12 Yahoo! Inc. Ranking content based on social network connection strengths
US20090077220A1 (en) * 2006-07-11 2009-03-19 Concert Technology Corporation System and method for identifying music content in a p2p real time recommendation network
US20090083147A1 (en) * 2007-09-21 2009-03-26 Toni Paila Separation of advertising content and control
US20090089352A1 (en) * 2007-09-28 2009-04-02 Yahoo!, Inc. Distributed live multimedia switching mechanism and network
US20090094848A1 (en) * 2006-01-31 2009-04-16 Deltarail Group Limited Track Twist Monitoring
US7523112B2 (en) * 2004-02-19 2009-04-21 Research In Motion Limited System and method for searching a remote database
US7530020B2 (en) * 2000-02-01 2009-05-05 Andrew J Szabo Computer graphic display visualization system and method
US20090125321A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
US20090124241A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for user profile match indication in a mobile environment
US7535884B2 (en) * 2006-04-18 2009-05-19 Cisco Technology, Inc. Battery-efficient generic advertising service for wireless mobile devices
US20100010733A1 (en) * 2008-07-09 2010-01-14 Microsoft Corporation Route prediction
US7657639B2 (en) * 2006-07-21 2010-02-02 International Business Machines Corporation Method and system for identity provider migration using federated single-sign-on operation
US7657522B1 (en) * 2006-01-12 2010-02-02 Recommind, Inc. System and method for providing information navigation and filtration
US20100030713A1 (en) * 2006-05-24 2010-02-04 Icom Limited Content engine
US7668922B2 (en) * 2006-01-19 2010-02-23 International Business Machines Corporation Identifying and displaying relevant shared entities in an instant messaging system
US20100064354A1 (en) * 2006-12-01 2010-03-11 David Irvine Maidsafe.net
US7689510B2 (en) * 2000-09-07 2010-03-30 Sonic Solutions Methods and system for use in network management of content
US7689682B1 (en) * 2006-08-16 2010-03-30 Resource Consortium Limited Obtaining lists of nodes of a multi-dimensional network
US7711004B2 (en) * 2006-04-18 2010-05-04 Cisco Technology, Inc. Multiple broadcast channels for wireless networks
US7716161B2 (en) * 2002-09-24 2010-05-11 Google, Inc, Methods and apparatus for serving relevant advertisements
US7904461B2 (en) * 2007-05-01 2011-03-08 Google Inc. Advertiser and user association
US8005716B1 (en) * 2004-06-30 2011-08-23 Google Inc. Methods and systems for establishing a keyword utilizing path navigation information
US8095582B2 (en) * 2006-05-02 2012-01-10 Surf Canyon Incorporated Dynamic search engine results employing user behavior
US8843536B1 (en) * 2004-12-31 2014-09-23 Google Inc. Methods and systems for providing relevant advertisements or other content for inactive uniform resource locators using search queries

Family Cites Families (267)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE2037580A1 (en) 1970-07-29 1972-02-03 J. Hengstler Kg, 7207 Aldingen Device for controlling a self-operated goods dispensing device by means of identification data carriers
JPH01162028A (en) 1987-12-18 1989-06-26 Nec Miyagi Ltd Alarm signal transmission system
JPH03122770A (en) 1989-10-05 1991-05-24 Ricoh Co Ltd Method for retrieving keyword associative document
WO1991017530A1 (en) * 1990-05-01 1991-11-14 Environmental Products Corporation A method of transferring display and print data
US5664126A (en) 1992-07-24 1997-09-02 Kabushiki Kaisha Toshiba Human interface system for communicating networked users
JP3140621B2 (en) 1993-09-28 2001-03-05 株式会社日立製作所 Distributed file system
US6460036B1 (en) 1994-11-29 2002-10-01 Pinpoint Incorporated System and method for providing customized electronic newspapers and target advertisements
US5778436A (en) 1995-03-06 1998-07-07 Duke University Predictive caching system and method based on memory access which previously followed a cache miss
US6112186A (en) 1995-06-30 2000-08-29 Microsoft Corporation Distributed system for facilitating exchange of user information and opinion using automated collaborative filtering
JP3360495B2 (en) 1995-08-09 2002-12-24 株式会社日立製作所 Mobile terminal
DE69630973T2 (en) 1995-11-06 2004-05-27 Motorola, Inc., Schaumburg MESSAGE STORAGE IN A SELECTIVE RECEIVER
US5918014A (en) 1995-12-27 1999-06-29 Athenium, L.L.C. Automated collaborative filtering in world wide web advertising
JPH09212397A (en) 1996-01-31 1997-08-15 Toshiba Corp File reading method
US5848397A (en) 1996-04-19 1998-12-08 Juno Online Services, L.P. Method and apparatus for scheduling the presentation of messages to computer users
IL128099A (en) 1996-07-22 2004-05-12 Cyva Res Corp Personal information security and exchange tool
US6601103B1 (en) * 1996-08-22 2003-07-29 Intel Corporation Method and apparatus for providing personalized supplemental programming
JPH1063618A (en) 1996-08-23 1998-03-06 Nippon Telegr & Teleph Corp <Ntt> Information providing system
CA2188845A1 (en) 1996-10-25 1998-04-25 Stephen Ross Todd Diversity Antenna Selection
US5948061A (en) * 1996-10-29 1999-09-07 Double Click, Inc. Method of delivery, targeting, and measuring advertising over networks
US6873834B1 (en) 1996-12-20 2005-03-29 Nortel Networks Limited Wireless terminal diversity scheme
US5961593A (en) 1997-01-22 1999-10-05 Lucent Technologies, Inc. System and method for providing anonymous personalized browsing by a proxy system in a network
JPH10294676A (en) 1997-04-17 1998-11-04 Yozan:Kk Standby circuit
US6105028A (en) 1997-06-26 2000-08-15 Digital Equipment Corporation Method and apparatus for accessing copies of documents using a web browser request interceptor
ES2475242T3 (en) 1997-07-21 2014-07-10 Gemstar Development Corporation Systems and methods for displaying and recording control interfaces
US6119098A (en) * 1997-10-14 2000-09-12 Patrice D. Guyot System and method for targeting and distributing advertisements over a distributed network
JPH11136365A (en) 1997-10-31 1999-05-21 Hitachi Ltd Information distribution system
JP3122770B2 (en) 1997-12-12 2001-01-09 大日精化工業株式会社 Coloring composition for image recording
GB2333379A (en) 1998-01-16 1999-07-21 Ibm Client/server computing
US6647257B2 (en) 1998-01-21 2003-11-11 Leap Wireless International, Inc. System and method for providing targeted messages based on wireless mobile location
CA2322026A1 (en) 1998-02-27 1999-09-02 Daniel Jaye System and method for building user profiles
US6026393A (en) 1998-03-31 2000-02-15 Casebank Technologies Inc. Configuration knowledge as an aid to case retrieval
GB2336006A (en) 1998-03-31 1999-10-06 Ibm Client/server computing with client selectable location of transaction objects
US6112203A (en) 1998-04-09 2000-08-29 Altavista Company Method for ranking documents in a hyperlinked environment using connectivity and selective content analysis
JPH11312190A (en) 1998-04-28 1999-11-09 Hitachi Ltd Method for displaying commodity information
JP4064060B2 (en) 1998-05-15 2008-03-19 ユニキャスト・コミュニケーションズ・コーポレイション Technology for implementing network-distributed interstitial web advertisements that are initiated by the browser and invisible to the user using ad tags embedded in reference web pages
US6256633B1 (en) 1998-06-25 2001-07-03 U.S. Philips Corporation Context-based and user-profile driven information retrieval
JP3328589B2 (en) 1998-07-23 2002-09-24 株式会社リクルート Terminal device, data stream generation device, data stream processing method, data stream generation method, and recording medium
US6654813B1 (en) * 1998-08-17 2003-11-25 Alta Vista Company Dynamically categorizing entity information
US6356879B2 (en) 1998-10-09 2002-03-12 International Business Machines Corporation Content based method for product-peer filtering
FR2784846B1 (en) 1998-10-15 2000-12-15 Cit Alcatel METHOD AND SYSTEM FOR MOBILE TELEPHONY USING SIGNALING MESSAGES WITH PRIORITY LEVELS
JP4465560B2 (en) 1998-11-20 2010-05-19 ソニー株式会社 Information display control device and information display control method for information display control device
JP2002531895A (en) 1998-11-30 2002-09-24 インデックス システムズ インコーポレイテッド Smart agents based on habits, statistical inference, and psychodemographic profiling
US7150030B1 (en) 1998-12-03 2006-12-12 Prime Research Alliance, Inc. Subscriber characterization system
US20020123928A1 (en) 2001-01-11 2002-09-05 Eldering Charles A. Targeting ads to subscribers based on privacy-protected subscriber profiles
CA2353646C (en) 1998-12-03 2004-04-06 Expanse Networks, Inc. Subscriber characterization and advertisement monitoring system
US7328448B2 (en) 2000-08-31 2008-02-05 Prime Research Alliance E, Inc. Advertisement distribution system for distributing targeted advertisements in television systems
US8290351B2 (en) 2001-04-03 2012-10-16 Prime Research Alliance E., Inc. Alternative advertising in prerecorded media
KR20010108011A (en) 1998-12-10 2001-12-07 추후제출 System and method for providing targeted messages based on wireless mobile location
US6611684B1 (en) * 1998-12-10 2003-08-26 Nortel Networks Limited Method and apparatus for implementing customer group functionality in a wireless environment
US6792412B1 (en) 1999-02-02 2004-09-14 Alan Sullivan Neural network system and method for controlling information output based on user feedback
US6668378B2 (en) * 1999-06-30 2003-12-23 Webtv Networks, Inc. Interactive television triggers having connected content/disconnected content attribute
FI107863B (en) 1999-10-11 2001-10-15 Sonera Oyj Procedures and systems for protecting a user identification
JP2001117977A (en) 1999-10-15 2001-04-27 Fuji Xerox Co Ltd Workflow system
US20030182567A1 (en) 1999-10-20 2003-09-25 Tivo Inc. Client-side multimedia content targeting system
JP2001128097A (en) 1999-10-28 2001-05-11 Nec Corp Information storing device for traveling object
US6834294B1 (en) 1999-11-10 2004-12-21 Screenboard Technologies Inc. Methods and systems for providing and displaying information on a keyboard
US7159232B1 (en) 1999-11-16 2007-01-02 Microsoft Corporation Scheduling the recording of television programs
US7031932B1 (en) 1999-11-22 2006-04-18 Aquantive, Inc. Dynamically optimizing the presentation of advertising messages
US6421673B1 (en) 1999-12-13 2002-07-16 Novient, Inc. Method for mapping applications and or attributes in a distributed network environment
US6981040B1 (en) 1999-12-28 2005-12-27 Utopy, Inc. Automatic, personalized online information and product services
JP2001203811A (en) 2000-01-19 2001-07-27 Index:Kk Communication system for mobile object
CA2298194A1 (en) 2000-02-07 2001-08-07 Profilium Inc. Method and system for delivering and targeting advertisements over wireless networks
JP2001222491A (en) 2000-02-09 2001-08-17 Nec Corp Information providing system, its method and client
JP3545666B2 (en) 2000-02-14 2004-07-21 株式会社東芝 Service providing system for mobile terminals
US6484148B1 (en) 2000-02-19 2002-11-19 John E. Boyd Electronic advertising device and method of using the same
JP2001238192A (en) 2000-02-21 2001-08-31 Nippon Telegr & Teleph Corp <Ntt> Information distribution system, information distribution method and terminal
WO2001065411A1 (en) 2000-02-29 2001-09-07 Thinairapps, Inc. Flexible wireless advertisement integration in wireless software applications
JP2001251576A (en) 2000-03-03 2001-09-14 Matsushita Electric Ind Co Ltd Program reception device and accumulation broadcast charging device
GB0005727D0 (en) 2000-03-10 2000-05-03 Koninkl Philips Electronics Nv Television
JP4414554B2 (en) 2000-03-22 2010-02-10 シャープ株式会社 Customer management system
JP2001273298A (en) 2000-03-23 2001-10-05 Hitachi Ltd Digital contents distribution system
US6499029B1 (en) 2000-03-29 2002-12-24 Koninklijke Philips Electronics N.V. User interface providing automatic organization and filtering of search criteria
JP4620830B2 (en) 2000-04-26 2011-01-26 株式会社 ボルテージ Advertisement delivery decision method and delivery optimization system
US8843590B2 (en) * 2000-05-31 2014-09-23 Ebm/Ip, Llc Systems, methods and computer program products for facilitating display of content within application programs executing on electronic devices
EP1358528A2 (en) 2000-07-13 2003-11-05 Koninklijke Philips Electronics N.V. Auditing system for e-commerce via consumer appliance
US6647261B1 (en) 2000-07-20 2003-11-11 Koninklijke Philips Electronics N.V. Idle handoff method taking into account critical system jobs
US6671732B1 (en) 2000-07-24 2003-12-30 Comverse Ltd. Method and apparatus for control of content based rich media streaming
JP4479087B2 (en) 2000-10-19 2010-06-09 ソニー株式会社 Broadcast system
US7403980B2 (en) 2000-11-08 2008-07-22 Sri International Methods and apparatus for scalable, distributed management of virtual private networks
JP2002197342A (en) 2000-12-25 2002-07-12 Hitachi Ltd Multiple dwelling house common site system and operation method therefor
JP2002197356A (en) 2000-12-26 2002-07-12 Toshiba Corp Commercial message providing method and system and storage medium
JP2002199460A (en) 2000-12-27 2002-07-12 Hitachi Ltd Information service system and information providing method
US20020087401A1 (en) 2000-12-29 2002-07-04 Gateway, Inc. System and method for targeted advertising
US20020091568A1 (en) * 2001-01-10 2002-07-11 International Business Machines Corporation Personalized profile based advertising system and method with integration of physical location using GPS
US7356530B2 (en) 2001-01-10 2008-04-08 Looksmart, Ltd. Systems and methods of retrieving relevant information
US7343317B2 (en) 2001-01-18 2008-03-11 Nokia Corporation Real-time wireless e-coupon (promotion) definition based on available segment
EP1356680B1 (en) 2001-02-02 2013-05-22 Opentv, Inc. A method and apparatus for reformatting of content for display on interactive television
US20020138331A1 (en) 2001-02-05 2002-09-26 Hosea Devin F. Method and system for web page personalization
US7298734B2 (en) * 2001-03-05 2007-11-20 Qwest Communications International, Inc. Method and system communication system message processing based on classification criteria
JP2002271855A (en) 2001-03-08 2002-09-20 Ntt Software Corp Advertisement providing system
US20020152117A1 (en) * 2001-04-12 2002-10-17 Mike Cristofalo System and method for targeting object oriented audio and video content to users
US6635015B2 (en) 2001-04-20 2003-10-21 The Procter & Gamble Company Body weight management system
JP2003208381A (en) 2001-04-20 2003-07-25 Nippon Telegr & Teleph Corp <Ntt> Token type contents presentation system, token type contents presentation method and portable user terminal
US20040139204A1 (en) 2001-04-23 2004-07-15 Siegried Ergezinger Architecture for providing services in the internet
US6968178B2 (en) * 2001-04-27 2005-11-22 Hewlett-Packard Development Company, L.P. Profiles for information acquisition by devices in a wireless network
JP2002334248A (en) 2001-05-07 2002-11-22 Honda Motor Co Ltd Computer system judging customer type in real time
JP2002333853A (en) 2001-05-08 2002-11-22 Hitachi Ltd System and method for distributing advertisement, and portable terminal equipment
JP2002366819A (en) 2001-05-31 2002-12-20 Hewlett Packard Co <Hp> Distribution system for electronic coupon based upon identifier
US7099952B2 (en) 2001-06-28 2006-08-29 Microsoft Corporation Transportable identifier and system and method to facilitate access to broadcast data
US7149704B2 (en) 2001-06-29 2006-12-12 Claria Corporation System, method and computer program product for collecting information about a network user
US6798358B2 (en) 2001-07-03 2004-09-28 Nortel Networks Limited Location-based content delivery
CA2394503A1 (en) 2001-07-23 2003-01-23 Research In Motion Limited System and method for pushing information to a mobile device
JP2003050932A (en) 2001-08-06 2003-02-21 Fuji Bolt Seisakusho:Kk Method and device for communication data relaying, and method and device for substitutional purchase by relaying of communication data
JP2003050820A (en) 2001-08-07 2003-02-21 Casio Comput Co Ltd Service information providing system, service information providing device and method therefor
JP3875051B2 (en) 2001-08-28 2007-01-31 株式会社エヌ・ティ・ティ・ドコモ COMMUNICATION SYSTEM, COMMUNICATION METHOD, AND COMMUNICATION CONTROL DEVICE
JP3612562B2 (en) * 2001-08-28 2005-01-19 独立行政法人情報通信研究機構 Digital data retrieval information presentation system
US20050210243A1 (en) 2001-09-28 2005-09-22 Archard Paul L System and method for improving client response times using an integrated security and packet optimization framework
US20030130887A1 (en) * 2001-10-03 2003-07-10 Thurston Nathaniel Non-deterministic method and system for the optimization of a targeted content delivery
US6947910B2 (en) 2001-10-09 2005-09-20 E-Cast, Inc. Secure ticketing
US7274684B2 (en) 2001-10-10 2007-09-25 Bruce Fitzgerald Young Method and system for implementing and managing a multimedia access network device
US7756520B2 (en) 2001-10-17 2010-07-13 Nortel Networks Limited Packet communication system with dual candidate sets for independent management of uplink and downlink transmissions
US6985811B2 (en) 2001-10-30 2006-01-10 Sirf Technology, Inc. Method and apparatus for real time clock (RTC) brownout detection
US7136871B2 (en) 2001-11-21 2006-11-14 Microsoft Corporation Methods and systems for selectively displaying advertisements
JP2003196128A (en) 2001-12-26 2003-07-11 Hitachi Ltd Portable information terminal, external storage device and information communication system
JP2003196305A (en) 2001-12-28 2003-07-11 Pfu Ltd Information distribution program, information distribution method and information distribution device
US20040203630A1 (en) 2002-03-15 2004-10-14 Wang Charles Chuanming Method and apparatus for targeting service delivery to mobile devices
JP2003283652A (en) 2002-03-25 2003-10-03 Nippon Telegr & Teleph Corp <Ntt> Voice advertisement distribution system using packet network
US20050215236A1 (en) 2002-03-28 2005-09-29 Andreas Myka Providing information for mobile users
US9235849B2 (en) 2003-12-31 2016-01-12 Google Inc. Generating user information for use in targeted advertising
US7346606B2 (en) 2003-06-30 2008-03-18 Google, Inc. Rendering advertisements with documents having one or more topics using user topic interest
JP2003316742A (en) 2002-04-24 2003-11-07 Nippon Telegr & Teleph Corp <Ntt> Anonymous communication method and device having single sign-on function
EP1514417A4 (en) 2002-05-31 2005-06-15 Predictive Media Corp Method and system for the storage, viewing management, and delivery of targeted advertising
JP2004005080A (en) 2002-05-31 2004-01-08 Sanyo Electric Co Ltd Information providing system and information providing method
JP2004013426A (en) 2002-06-05 2004-01-15 Nippon Telegr & Teleph Corp <Ntt> Multimedia information providing system and method thereof, and multimedia information providing program and recording medium thereof
US20040165006A1 (en) 2002-07-19 2004-08-26 Timothy Kirby Methods and apparatus for an interactive media display
US7254643B1 (en) 2002-08-08 2007-08-07 At&T Corp. System and method for providing multi-media services to communication devices over a communications network
KR20040032260A (en) 2002-10-08 2004-04-17 전자부품연구원 Advertisements display apparatus using metadata and its service method
JP2004086560A (en) 2002-08-27 2004-03-18 Yamaha Corp Information distribution system and method, as well as information distribution control device, method and program
GB2392518B (en) 2002-09-02 2004-09-22 3Com Corp Computer network and method of operating same to preload content of selected web pages
JP3722229B2 (en) 2002-10-10 2005-11-30 松下電器産業株式会社 Information acquisition method, information presentation method, and information acquisition device
JP2007263972A (en) 2002-10-10 2007-10-11 Matsushita Electric Ind Co Ltd Information presenting method and device
JP2004138692A (en) 2002-10-16 2004-05-13 Hitachi Eng Co Ltd Internet advertisement information providing system
JP2004151954A (en) 2002-10-30 2004-05-27 Ntt Comware Corp Advertising mail delivery device and advertising mail delivery method
KR100453674B1 (en) 2002-11-08 2004-10-20 지에스티 주식회사 A trigonal prism turning display device for advertisement
KR20040040779A (en) 2002-11-08 2004-05-13 주식회사 비즈모델라인 System and Method for Management a Record of Expenditure by Using Smart Card(IC Card)
EP1567963B1 (en) 2002-12-03 2008-07-30 Research In Motion Limited Method, system and computer software product for pre-selecting a folder for a message
US7512403B2 (en) 2002-12-20 2009-03-31 Samsung Electronics Co., Ltd. Apparatus and method for performing an interfrequency handoff in a wireless network
US20040128347A1 (en) 2002-12-31 2004-07-01 Jeffrey Mason System and method for providing content access at remote portal environments
CN1759380A (en) 2003-03-10 2006-04-12 皇家飞利浦电子股份有限公司 Content exchange between portable device and network
JP2004294264A (en) 2003-03-27 2004-10-21 Mazda Motor Corp Navigation system
US7577732B2 (en) 2003-03-28 2009-08-18 Fujitsu Limited Information distribution service providing system
JP2004320153A (en) 2003-04-11 2004-11-11 Sony Corp Radio communication system and power control method thereof
JP2006526817A (en) 2003-05-12 2006-11-24 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ Apparatus and method for performing profile-based collaborative filtering
US20040243482A1 (en) 2003-05-28 2004-12-02 Steven Laut Method and apparatus for multi-way jukebox system
US20060179107A1 (en) 2003-06-18 2006-08-10 Yoshiaki Iwata Network recording system, recording server, and terminal device
JP2005070889A (en) 2003-08-28 2005-03-17 Shunji Sugaya Attribute judgment system, method, and computer program
US8527346B2 (en) 2003-09-29 2013-09-03 Yahoo! Inc. Method and system for scheduling electronic advertising
US20050128995A1 (en) * 2003-09-29 2005-06-16 Ott Maximilian A. Method and apparatus for using wireless hotspots and semantic routing to provide broadband mobile serveices
JP2005107728A (en) 2003-09-29 2005-04-21 Hitachi Software Eng Co Ltd Advertisement display system and advertisement display method in cellphone terminal
US20050222989A1 (en) 2003-09-30 2005-10-06 Taher Haveliwala Results based personalization of advertisements in a search engine
US8321278B2 (en) * 2003-09-30 2012-11-27 Google Inc. Targeted advertisements based on user profiles and page profile
EP1668859B1 (en) * 2003-09-30 2010-04-14 Telefonaktiebolaget LM Ericsson (publ) Means and method for generating a unique user's identity for use between different domains
US7693827B2 (en) 2003-09-30 2010-04-06 Google Inc. Personalization of placed content ordering in search results
US20050071328A1 (en) 2003-09-30 2005-03-31 Lawrence Stephen R. Personalization of web search
FI116808B (en) 2003-10-06 2006-02-28 Leiki Oy An arrangement and method for providing information to a user
US7312752B2 (en) 2003-10-22 2007-12-25 Awarepoint Corporation Wireless position location and tracking system
US7552433B2 (en) 2003-11-12 2009-06-23 Hewlett-Packard Development Company, L.P. Non-platform-specific unique indentifier generation
JP4285225B2 (en) 2003-12-11 2009-06-24 沖電気工業株式会社 Relay device, network system, network access method, and program
US20050216823A1 (en) 2003-12-30 2005-09-29 Microsoft Corporation Assigning textual ads based on article history
US7216205B2 (en) 2004-01-12 2007-05-08 Hewlett-Packard Development Company, L.P. Cache line ownership transfer in multi-processor computer systems
EP1577819A1 (en) * 2004-01-26 2005-09-21 Quad/Graphics, Inc. Advertising management system and method of operation
US7599991B2 (en) 2004-03-10 2009-10-06 Microsoft Corporation Rules interface for implementing message rules on a mobile computing device
US20050215238A1 (en) * 2004-03-24 2005-09-29 Macaluso Anthony G Advertising on mobile devices
US20050262246A1 (en) 2004-04-19 2005-11-24 Satish Menon Systems and methods for load balancing storage and streaming media requests in a scalable, cluster-based architecture for real-time streaming
US7616613B2 (en) 2004-05-05 2009-11-10 Cisco Technology, Inc. Internet protocol authentication in layer-3 multipoint tunneling for wireless access points
JP2005332265A (en) 2004-05-20 2005-12-02 Sony Corp Information processing system and method, information processor and method, and program
US7502344B2 (en) * 2004-06-25 2009-03-10 Fujifilm Corporation Communications terminal, server, playback control method and program
US7716219B2 (en) 2004-07-08 2010-05-11 Yahoo ! Inc. Database search system and method of determining a value of a keyword in a search
JP2006031204A (en) 2004-07-14 2006-02-02 Recruit Co Ltd Information matching apparatus
JP2006053767A (en) 2004-08-12 2006-02-23 Ntt Comware Corp Content distribution system and method, content distribution server, client terminal, and computer program
US7860922B2 (en) 2004-08-18 2010-12-28 Time Warner, Inc. Method and device for the wireless exchange of media content between mobile devices based on content preferences
KR20060017990A (en) 2004-08-23 2006-02-28 남기열 Information (advertising/coupon) sending service model through handy phone(mobile phone) with credit card transaction
US7707167B2 (en) * 2004-09-20 2010-04-27 Microsoft Corporation Method, system, and apparatus for creating a knowledge interchange profile
JP4880962B2 (en) 2004-09-27 2012-02-22 ヤフー株式会社 Advertisement content distribution ratio calculation program, advertisement content distribution ratio calculation method, advertisement content distribution ratio calculation system, content distribution control system, advertisement content distribution control system, advertisement content distribution control method, and advertisement content distribution control program
US11283885B2 (en) * 2004-10-19 2022-03-22 Verizon Patent And Licensing Inc. System and method for location based matching and promotion
KR101061265B1 (en) 2004-10-19 2011-08-31 야후! 인크. System and method for location based social networking
US20060165005A1 (en) * 2004-11-15 2006-07-27 Microsoft Corporation Business method for pay-as-you-go computer and dynamic differential pricing
FR2878670B1 (en) 2004-11-26 2007-04-20 Himanshu Sekhar METHOD OF ENHANCING ERGONOMICS AND SPEED OF ACCESS TO INFORMATION
US7869453B2 (en) 2004-12-17 2011-01-11 Lantiq Deutschland Gmbh Apparatus and method for data transfer
JP2008525875A (en) 2004-12-23 2008-07-17 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ Method and apparatus for recommending content
JP4331101B2 (en) 2004-12-27 2009-09-16 株式会社東芝 Cache control device, cache control method, and cache control program
JP2006203593A (en) 2005-01-21 2006-08-03 Hitachi Ltd System and method for televiewing tv broadcast
US20070168461A1 (en) * 2005-02-01 2007-07-19 Moore James F Syndicating surgical data in a healthcare environment
JP2006215956A (en) 2005-02-07 2006-08-17 Nomura Research Institute Ltd Online advertising system and online advertising method
US20060194569A1 (en) 2005-02-25 2006-08-31 Leapfrog Technologies, Inc. Wireless electronic coupon delivery system for use by mobile communication devices
US8768766B2 (en) * 2005-03-07 2014-07-01 Turn Inc. Enhanced online advertising system
JP4650037B2 (en) 2005-03-11 2011-03-16 日本電気株式会社 Data management apparatus, mobile phone, data management method, program, recording medium
JP2006261956A (en) 2005-03-16 2006-09-28 Hochiki Corp Notice broadcast system
US9288538B2 (en) 2005-04-07 2016-03-15 Qualcomm Incorporated Methods and apparatus for conveying a delivery schedule to mobile terminals
US7610280B2 (en) 2005-05-05 2009-10-27 Cisco Technology, Inc. Method and system for dynamically pre-positioning content in a network based detecting or predicting user presence
US7653627B2 (en) * 2005-05-13 2010-01-26 Microsoft Corporation System and method for utilizing the content of an online conversation to select advertising content and/or other relevant information for display
US20060271425A1 (en) 2005-05-27 2006-11-30 Microsoft Corporation Advertising in application programs
US20060277098A1 (en) 2005-06-06 2006-12-07 Chung Tze D Media playing system and method for delivering multimedia content with up-to-date and targeted marketing messages over a communication network
US20060277271A1 (en) 2005-06-07 2006-12-07 Yahoo! Inc. Prefetching content based on a mobile user profile
US20060282312A1 (en) 2005-06-10 2006-12-14 Microsoft Corporation Advertisements in an alert interface
US20060293065A1 (en) 2005-06-27 2006-12-28 Lucent Technologies Inc. Dynamic information on demand
US20060294084A1 (en) 2005-06-28 2006-12-28 Patel Jayendu S Methods and apparatus for a statistical system for targeting advertisements
JP2007017841A (en) 2005-07-11 2007-01-25 Seiji Wada Electronic mail advertisement delivery system
JP2007089131A (en) 2005-07-25 2007-04-05 Sony Corp Information processor and method, program, and recording medium
RU2421800C2 (en) 2005-08-01 2011-06-20 Конинклейке Филипс Электроникс Н.В. Organisation of content by means of dynamic profile
JP4398916B2 (en) 2005-08-12 2010-01-13 株式会社東芝 Probabilistic model generation apparatus and program
US20080215623A1 (en) 2005-09-14 2008-09-04 Jorey Ramer Mobile communication facility usage and social network creation
US20070060114A1 (en) 2005-09-14 2007-03-15 Jorey Ramer Predictive text completion for a mobile communication facility
US20080214153A1 (en) 2005-09-14 2008-09-04 Jorey Ramer Mobile User Profile Creation based on User Browse Behaviors
US7702318B2 (en) 2005-09-14 2010-04-20 Jumptap, Inc. Presentation of sponsored content based on mobile transaction event
US8195133B2 (en) 2005-09-14 2012-06-05 Jumptap, Inc. Mobile dynamic advertisement creation and placement
US7979509B1 (en) 2005-09-15 2011-07-12 Juniper Networks, Inc. Clustered network acceleration devices having shared cache
US7761075B2 (en) 2005-09-21 2010-07-20 Samsung Electronics Co., Ltd. Apparatus and method for interference cancellation in wireless mobile stations operating concurrently on two or more air interfaces
GB2430524A (en) 2005-09-23 2007-03-28 Avantone Oy Mobile information processing system
JP2007094560A (en) 2005-09-27 2007-04-12 Nec Corp Service providing method, service providing system, service providing device, service providing terminal and service providing program
US20070088801A1 (en) * 2005-10-17 2007-04-19 Zohar Levkovitz Device, system and method of delivering targeted advertisements using wireless application protocol
WO2007045257A1 (en) 2005-10-18 2007-04-26 Telecom Italia S.P.A. A method for controlling access to file systems, related system, sim card and computer program product for use therein
US7628325B2 (en) 2005-11-08 2009-12-08 At&T Intellectual Property I, Lp Systems, methods and computer program products for wirelessly preprocessing a transaction while in a queue for a point-of-transaction
US20070111726A1 (en) 2005-11-15 2007-05-17 Sony Ericsson Mobile Communications Ab User profiles for mobile terminals
US20070136742A1 (en) * 2005-12-13 2007-06-14 General Instrument Corporation Method, apparatus and system for replacing advertisements in recorded video content
US7805129B1 (en) 2005-12-27 2010-09-28 Qurio Holdings, Inc. Using device content information to influence operation of another device
WO2007082190A2 (en) 2006-01-06 2007-07-19 Qualcomm Incorporated Apparatus and methods of selective collection and selective presentation of content
US20070288310A1 (en) 2006-01-24 2007-12-13 Boos Frederick B Methods and systems for providing advertising to consumers
US7756922B2 (en) 2006-01-27 2010-07-13 Oracle International Corporation Schema annotations for managing cached document fragments
EP1992096A2 (en) 2006-02-28 2008-11-19 Nokia Corporation Multicast group address signaling using mac header for power save delivery in a wireless network
US7903817B2 (en) 2006-03-02 2011-03-08 Cisco Technology, Inc. System and method for wireless network profile provisioning
US20070208728A1 (en) 2006-03-03 2007-09-06 Microsoft Corporation Predicting demographic attributes based on online behavior
JP2007241921A (en) 2006-03-13 2007-09-20 Keiji Ariyama Advertisement distributing system and advertisement distributing method
JP2007264764A (en) 2006-03-27 2007-10-11 Denso It Laboratory Inc Content sorting method
JP2007271305A (en) 2006-03-30 2007-10-18 Suzuki Motor Corp Information distribution system
US10803468B2 (en) 2006-04-18 2020-10-13 At&T Intellectual Property I, L.P. Method and apparatus for selecting advertising
US8571580B2 (en) 2006-06-01 2013-10-29 Loopt Llc. Displaying the location of individuals on an interactive map display on a mobile communication device
US7814112B2 (en) 2006-06-09 2010-10-12 Ebay Inc. Determining relevancy and desirability of terms
US8175645B2 (en) 2006-06-12 2012-05-08 Qurio Holdings, Inc. System and method for modifying a device profile
US7997485B2 (en) * 2006-06-29 2011-08-16 Microsoft Corporation Content presentation based on user preferences
US20080010157A1 (en) 2006-07-08 2008-01-10 Raj Prakash Deploying Advertisement Objects With Vendor Transaction Objects
US20080133327A1 (en) 2006-09-14 2008-06-05 Shah Ullah Methods and systems for securing content played on mobile devices
JP4240094B2 (en) 2006-09-19 2009-03-18 船井電機株式会社 Content receiving system
JP5016880B2 (en) * 2006-09-21 2012-09-05 富士通株式会社 Memory management method and apparatus according to priority class
US7962369B2 (en) 2006-09-29 2011-06-14 Einar Rosenberg Apparatus and method using near field communications
US8036632B1 (en) 2007-02-02 2011-10-11 Resource Consortium Limited Access of information using a situational network
US8646016B2 (en) 2006-12-06 2014-02-04 Verizon Patent And Licensing Inc. Content storage and delivery systems and associated methods
US20080140667A1 (en) 2006-12-07 2008-06-12 Sony Ericsson Mobile Communications Ab Device and method for creating a transaction log of data exchanges between a portable mobile communications device and other wireless devices
US20080140941A1 (en) 2006-12-07 2008-06-12 Dasgupta Gargi B Method and System for Hoarding Content on Mobile Clients
US20080153513A1 (en) 2006-12-20 2008-06-26 Microsoft Corporation Mobile ad selection and filtering
US7840685B2 (en) 2007-01-07 2010-11-23 Apple Inc. Handheld computer having dynamic network transport selection according to a media type of a request
US20080215348A1 (en) 2007-03-02 2008-09-04 Marc Guldimann System and methods for advertisement and event promotion
JP4686491B2 (en) 2007-03-02 2011-05-25 株式会社シリウステクノロジーズ Advertisement information display method, advertisement information display system, and advertisement information transmission program
US20080228568A1 (en) 2007-03-16 2008-09-18 Microsoft Corporation Delivery of coupons through advertisement
US7702620B2 (en) * 2007-03-29 2010-04-20 International Business Machines Corporation System and method for ranked keyword search on graphs
US20080249987A1 (en) 2007-04-06 2008-10-09 Gemini Mobile Technologies, Inc. System And Method For Content Selection Based On User Profile Data
US20080276266A1 (en) 2007-04-18 2008-11-06 Google Inc. Characterizing content for identification of advertising
EP2150902A4 (en) 2007-04-22 2012-03-21 Phone Through Inc Methods and apparatus related to content sharing between devices
US20080275771A1 (en) 2007-05-01 2008-11-06 Visa U.S.A. Inc. Merchant transaction based advertising
US20080281940A1 (en) 2007-05-11 2008-11-13 Sony Ericsson Mobile Communications Ab Advertising on a portable communication device
US8073423B2 (en) 2007-05-25 2011-12-06 At&T Mobility Ii Llc Intelligent information control repository
US8027954B2 (en) 2007-05-31 2011-09-27 Red Hat, Inc. Portable media player recommendation system
US7702813B2 (en) 2007-06-08 2010-04-20 Sony Ericsson Mobile Communications Ab Using personal data for advertisements
US8249922B2 (en) 2007-06-15 2012-08-21 Alcatel Lucent Method and apparatus for advertisement delivery in wireless networks
US20090006183A1 (en) * 2007-06-29 2009-01-01 The Western Union Company Methods and systems for customized coupon generation
US9392074B2 (en) 2007-07-07 2016-07-12 Qualcomm Incorporated User profile generation architecture for mobile content-message targeting
US20100217881A1 (en) 2007-09-12 2010-08-26 Panasonic Corporation Wireless terminal device, wireless connection method, and program
US20090076882A1 (en) * 2007-09-14 2009-03-19 Microsoft Corporation Multi-modal relevancy matching
US20090094248A1 (en) 2007-10-03 2009-04-09 Concert Technology Corporation System and method of prioritizing the downloading of media items in a media item recommendation network
US9391789B2 (en) 2007-12-14 2016-07-12 Qualcomm Incorporated Method and system for multi-level distribution information cache management in a mobile environment
US8234159B2 (en) 2008-03-17 2012-07-31 Segmint Inc. Method and system for targeted content placement
US7487017B1 (en) 2008-03-31 2009-02-03 International Business Machines Corporation Systems and methods for generating pattern keys for use in navigation systems to predict user destinations
US8966001B2 (en) 2008-09-02 2015-02-24 Qualcomm Incorporated Deployment and distribution model for improved content delivery system
US20100057924A1 (en) 2008-09-02 2010-03-04 Qualcomm Incorporated Access point for improved content delivery system
US9152411B2 (en) 2010-05-12 2015-10-06 Microsoft Technology Licensing, Llc Edge computing platform for delivery of rich internet applications
US20110282964A1 (en) * 2010-05-13 2011-11-17 Qualcomm Incorporated Delivery of targeted content related to a learned and predicted future behavior based on spatial, temporal, and user attributes and behavioral constraints
US9286084B2 (en) * 2013-12-30 2016-03-15 Qualcomm Incorporated Adaptive hardware reconfiguration of configurable co-processor cores for hardware optimization of functionality blocks based on use case prediction, and related methods, circuits, and computer-readable media

Patent Citations (106)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6202058B1 (en) * 1994-04-25 2001-03-13 Apple Computer, Inc. System for ranking the relevance of information objects accessed by computer users
US5754938A (en) * 1994-11-29 1998-05-19 Herz; Frederick S. M. Pseudonymous server for system for customized electronic identification of desirable objects
US5754939A (en) * 1994-11-29 1998-05-19 Herz; Frederick S. M. System for generation of user profiles for a system for customized electronic identification of desirable objects
US6411807B1 (en) * 1996-02-05 2002-06-25 At&T Wireless Service, Inc. Roaming authorization system
US20030040332A1 (en) * 1996-09-05 2003-02-27 Jerome Swartz System for digital radio communication between a wireless LAN and a PBX
US6177931B1 (en) * 1996-12-19 2001-01-23 Index Systems, Inc. Systems and methods for displaying and recording control interface with television programs, video, advertising information and program scheduling information
US20060069749A1 (en) * 1997-12-05 2006-03-30 Pinpoint Incorporated Location enhanced information delivery system
US6571279B1 (en) * 1997-12-05 2003-05-27 Pinpoint Incorporated Location enhanced information delivery system
US6738678B1 (en) * 1998-01-15 2004-05-18 Krishna Asur Bharat Method for ranking hyperlinked pages using content and connectivity analysis
US6677894B2 (en) * 1998-04-28 2004-01-13 Snaptrack, Inc Method and apparatus for providing location-based information via a computer network
US6510318B1 (en) * 1998-07-28 2003-01-21 Nec Corporation Method for location registration of mobile stations in a mobile communications system
US20020010625A1 (en) * 1998-09-18 2002-01-24 Smith Brent R. Content personalization based on actions performed during a current browsing session
US20080092168A1 (en) * 1999-03-29 2008-04-17 Logan James D Audio and video program recording, editing and playback systems using metadata
US7065525B1 (en) * 1999-06-30 2006-06-20 Denso Corporation Information service system for providing terminal users with terminal user specific information
US20020046084A1 (en) * 1999-10-08 2002-04-18 Scott A. Steele Remotely configurable multimedia entertainment and information system with location based advertising
US6895387B1 (en) * 1999-10-29 2005-05-17 Networks Associates Technology, Inc. Dynamic marketing based on client computer configurations
US20030055729A1 (en) * 1999-11-10 2003-03-20 Bezos Jeffrey P. Method and system for allocating display space
US20020069105A1 (en) * 1999-12-02 2002-06-06 Do Rosario Botelho Alfredo Agnelo Judas Sebastiao Data processing system for targeted content
US20060053077A1 (en) * 1999-12-09 2006-03-09 International Business Machines Corporation Digital content distribution using web broadcasting services
US6847959B1 (en) * 2000-01-05 2005-01-25 Apple Computer, Inc. Universal interface for retrieval of information in a computer system
US7530020B2 (en) * 2000-02-01 2009-05-05 Andrew J Szabo Computer graphic display visualization system and method
US7330824B1 (en) * 2000-02-25 2008-02-12 Navic Systems, Inc. Method and system for content profiling and activation
US6912398B1 (en) * 2000-04-10 2005-06-28 David Domnitz Apparatus and method for delivering information to an individual based on location and/or time
US20020003162A1 (en) * 2000-04-17 2002-01-10 Ferber John B. Apparatus and method for delivery of targeted marketing to automated service machines
US20030110080A1 (en) * 2000-04-26 2003-06-12 Yuzi Tsutani Advertisement distribution determining/optimizing method
US7069319B2 (en) * 2000-06-30 2006-06-27 Bellsouth Intellectual Property Corporation Anonymous location service for wireless networks
US20020032771A1 (en) * 2000-07-20 2002-03-14 Trond Gledje Event-based advertisements
US20070037610A1 (en) * 2000-08-29 2007-02-15 Logan James D Methods and apparatus for conserving battery power in a cellular or portable telephone
US7689510B2 (en) * 2000-09-07 2010-03-30 Sonic Solutions Methods and system for use in network management of content
US20020062251A1 (en) * 2000-09-29 2002-05-23 Rajan Anandan System and method for wireless consumer communications
US20070022375A1 (en) * 2000-10-19 2007-01-25 David Walker Apparatus, system, and method for an electronic payment system
US20040049537A1 (en) * 2000-11-20 2004-03-11 Titmuss Richard J Method of managing resources
US7370073B2 (en) * 2000-11-28 2008-05-06 Navic Systems, Inc. Using viewership profiles for targeted promotion deployment
US20060136742A1 (en) * 2000-12-27 2006-06-22 Giobbi John J Personal digital key and receiver/decoder circuit system and method
US6526440B1 (en) * 2001-01-30 2003-02-25 Google, Inc. Ranking search results by reranking the results based on local inter-connectivity
US20080077502A1 (en) * 2001-02-17 2008-03-27 Ttb Technologies, Llc Electronic advertising device and method of using the same
US7222101B2 (en) * 2001-02-26 2007-05-22 American Express Travel Related Services Company, Inc. System and method for securing data through a PDA portal
US20030003929A1 (en) * 2001-03-29 2003-01-02 International Business Machines Corporation Method and system for schedule based advertising on a mobile phone
US6889224B2 (en) * 2001-05-16 2005-05-03 International Business Machines Corporation Method for storing, accessing embedded web pages during manufacturing phase on personal digital device
US6507279B2 (en) * 2001-06-06 2003-01-14 Sensormatic Electronics Corporation Complete integrated self-checkout system and method
US20030023489A1 (en) * 2001-06-14 2003-01-30 Mcguire Myles P. Method and system for providing network based target advertising
US20060089128A1 (en) * 2001-12-19 2006-04-27 Smith Alan A Method of an apparatus for handling messages in a mobile communications enviroment
US7363035B2 (en) * 2002-02-07 2008-04-22 Qualcomm Incorporated Method and apparatus for providing content to a mobile terminal
US7069259B2 (en) * 2002-06-28 2006-06-27 Microsoft Corporation Multi-attribute specification of preferences about people, priorities and privacy for guiding messaging and communications
US20060008918A1 (en) * 2002-07-18 2006-01-12 Probert Christopher S J Detection of disease by analysis of emissions
US7716161B2 (en) * 2002-09-24 2010-05-11 Google, Inc, Methods and apparatus for serving relevant advertisements
US20040093418A1 (en) * 2002-11-13 2004-05-13 Jukka Tuomi Update of subscriber profiles in a communication system
US20050063365A1 (en) * 2003-07-11 2005-03-24 Boban Mathew System and method for multi-tiered rule filtering
US20050120003A1 (en) * 2003-10-08 2005-06-02 Drury William J. Method for maintaining a record of searches and results
US20050149395A1 (en) * 2003-10-29 2005-07-07 Kontera Technologies, Inc. System and method for real-time web page context analysis for the real-time insertion of textual markup objects and dynamic content
US7523112B2 (en) * 2004-02-19 2009-04-21 Research In Motion Limited System and method for searching a remote database
US8005716B1 (en) * 2004-06-30 2011-08-23 Google Inc. Methods and systems for establishing a keyword utilizing path navigation information
US20060039303A1 (en) * 2004-08-18 2006-02-23 Howard Singer Method and apparatus for wirelessly sharing a file using an application-level connection
US20060041638A1 (en) * 2004-08-23 2006-02-23 Ianywhere Solutions, Inc. Method, system, and computer program product for offline advertisement servicing and cycling
US20060041472A1 (en) * 2004-08-23 2006-02-23 Lukose Rajan M Systems and methods of interfacing an advertisement with a message presentation client
US20060064346A1 (en) * 2004-08-31 2006-03-23 Qualcomm Incorporated Location based service (LBS) system and method for targeted advertising
US20060059183A1 (en) * 2004-09-16 2006-03-16 Pearson Malcolm E Securely publishing user profile information across a public insecure infrastructure
US20060064386A1 (en) * 2004-09-20 2006-03-23 Aaron Marking Media on demand via peering
US20060089138A1 (en) * 2004-10-26 2006-04-27 Smith Brian K Method of scanning for beacon transmissions in WLAN
US20060129931A1 (en) * 2004-12-10 2006-06-15 Microsoft Corporation Integrated client help viewer for internet-based and local help content
US8843536B1 (en) * 2004-12-31 2014-09-23 Google Inc. Methods and systems for providing relevant advertisements or other content for inactive uniform resource locators using search queries
US20070005419A1 (en) * 2005-06-30 2007-01-04 Microsoft Corporation Recommending location and services via geospatial collaborative filtering
US20070022098A1 (en) * 2005-07-25 2007-01-25 Dale Malik Systems and methods for automatically updating annotations and marked content of an information search
US20070088603A1 (en) * 2005-10-13 2007-04-19 Jouppi Norman P Method and system for targeted data delivery using weight-based scoring
US7706740B2 (en) * 2006-01-06 2010-04-27 Qualcomm Incorporated Apparatus and methods of selective collection and selective presentation of content
US20080090513A1 (en) * 2006-01-06 2008-04-17 Qualcomm Incorporated Apparatus and methods of selective collection and selective presentation of content
US7657522B1 (en) * 2006-01-12 2010-02-02 Recommind, Inc. System and method for providing information navigation and filtration
US7668922B2 (en) * 2006-01-19 2010-02-23 International Business Machines Corporation Identifying and displaying relevant shared entities in an instant messaging system
US20090094848A1 (en) * 2006-01-31 2009-04-16 Deltarail Group Limited Track Twist Monitoring
US7711004B2 (en) * 2006-04-18 2010-05-04 Cisco Technology, Inc. Multiple broadcast channels for wireless networks
US7535884B2 (en) * 2006-04-18 2009-05-19 Cisco Technology, Inc. Battery-efficient generic advertising service for wireless mobile devices
US20070255690A1 (en) * 2006-04-28 2007-11-01 Chi-Chao Chang System and method for forecasting the performance of advertisements
US8095582B2 (en) * 2006-05-02 2012-01-10 Surf Canyon Incorporated Dynamic search engine results employing user behavior
US20100030713A1 (en) * 2006-05-24 2010-02-04 Icom Limited Content engine
US20080010144A1 (en) * 2006-06-27 2008-01-10 Adchemy, Inc. System and method for generating target bids for advertisement group keywords
US20080004952A1 (en) * 2006-06-30 2008-01-03 Nokia Corporation Advertising Middleware
US20090077220A1 (en) * 2006-07-11 2009-03-19 Concert Technology Corporation System and method for identifying music content in a p2p real time recommendation network
US7657639B2 (en) * 2006-07-21 2010-02-02 International Business Machines Corporation Method and system for identity provider migration using federated single-sign-on operation
US20080082417A1 (en) * 2006-07-31 2008-04-03 Publicover Mark W Advertising and fulfillment system
US7689682B1 (en) * 2006-08-16 2010-03-30 Resource Consortium Limited Obtaining lists of nodes of a multi-dimensional network
US20080060000A1 (en) * 2006-08-31 2008-03-06 Francois-Xavier Drouet Personalized advertising in mobile television
US20080091796A1 (en) * 2006-09-29 2008-04-17 Guy Story Methods and apparatus for customized content delivery
US20080092171A1 (en) * 2006-10-03 2008-04-17 Verizon Data Services Inc. Control tools for media content access systems and methods
US20080098420A1 (en) * 2006-10-19 2008-04-24 Roundbox, Inc. Distribution and display of advertising for devices in a network
US20080109376A1 (en) * 2006-10-30 2008-05-08 Maxlinear, Inc. Targeted advertisement in the digital television environment
US20080103971A1 (en) * 2006-10-31 2008-05-01 Rajan Mathew Lukose Method and system for tracking conversions in a system for targeted data delivery
US20100064354A1 (en) * 2006-12-01 2010-03-11 David Irvine Maidsafe.net
US20090044246A1 (en) * 2007-02-01 2009-02-12 Patrick Sheehan Targeting content based on location
US20080248815A1 (en) * 2007-04-08 2008-10-09 James David Busch Systems and Methods to Target Predictive Location Based Content and Track Conversions
US7904461B2 (en) * 2007-05-01 2011-03-08 Google Inc. Advertiser and user association
US20090061884A1 (en) * 2007-06-20 2009-03-05 Rajan Rajeev D Dynamic electronic coupon for a mobile environment
US20090013024A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Methods and systems for providing targeted information using identity masking in a wireless communications device
US20090011744A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for delivery of targeted information based on a user profile in a mobile communication device
US20090012861A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for providing targeted information using profile attributes with variable confidence levels in a mobile environment
US20090048977A1 (en) * 2007-07-07 2009-02-19 Qualcomm Incorporated User profile generation architecture for targeted content distribution using external processes
US20090011740A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for providing targeted information based on a user profile in a mobile environment
US20090013051A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method for transfer of information related to targeted content messages through a proxy server
US20090049090A1 (en) * 2007-08-13 2009-02-19 Research In Motion Limited System and method for facilitating targeted mobile advertisement
US20090070700A1 (en) * 2007-09-07 2009-03-12 Yahoo! Inc. Ranking content based on social network connection strengths
US20090083147A1 (en) * 2007-09-21 2009-03-26 Toni Paila Separation of advertising content and control
US20090089352A1 (en) * 2007-09-28 2009-04-02 Yahoo!, Inc. Distributed live multimedia switching mechanism and network
US20090125585A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
US20090125321A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
US20090124241A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for user profile match indication in a mobile environment
US20090125462A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US20100010733A1 (en) * 2008-07-09 2010-01-14 Microsoft Corporation Route prediction

Cited By (151)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8892495B2 (en) 1991-12-23 2014-11-18 Blanding Hovenweep, Llc Adaptive pattern recognition based controller apparatus and method and human-interface therefore
US9535563B2 (en) 1999-02-01 2017-01-03 Blanding Hovenweep, Llc Internet appliance system and method
US9507778B2 (en) 2006-05-19 2016-11-29 Yahoo! Inc. Summarization of media object collections
US8594702B2 (en) 2006-11-06 2013-11-26 Yahoo! Inc. Context server for associating information based on context
US20080120308A1 (en) * 2006-11-22 2008-05-22 Ronald Martinez Methods, Systems and Apparatus for Delivery of Media
US20090024452A1 (en) * 2006-11-22 2009-01-22 Ronald Martinez Methods, systems and apparatus for delivery of media
US9110903B2 (en) 2006-11-22 2015-08-18 Yahoo! Inc. Method, system and apparatus for using user profile electronic device data in media delivery
US8402356B2 (en) 2006-11-22 2013-03-19 Yahoo! Inc. Methods, systems and apparatus for delivery of media
US8769099B2 (en) 2006-12-28 2014-07-01 Yahoo! Inc. Methods and systems for pre-caching information on a mobile computing device
US20090319329A1 (en) * 2007-07-07 2009-12-24 Qualcomm Incorporated User profile generation architecture for mobile content-message targeting
US9485322B2 (en) 2007-07-07 2016-11-01 Qualcomm Incorporated Method and system for providing targeted information using profile attributes with variable confidence levels in a mobile environment
US20090048977A1 (en) * 2007-07-07 2009-02-19 Qualcomm Incorporated User profile generation architecture for targeted content distribution using external processes
US20090011740A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for providing targeted information based on a user profile in a mobile environment
US9596317B2 (en) 2007-07-07 2017-03-14 Qualcomm Incorporated Method and system for delivery of targeted information based on a user profile in a mobile communication device
US20090013024A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Methods and systems for providing targeted information using identity masking in a wireless communications device
US9497286B2 (en) 2007-07-07 2016-11-15 Qualcomm Incorporated Method and system for providing targeted information based on a user profile in a mobile environment
US9392074B2 (en) 2007-07-07 2016-07-12 Qualcomm Incorporated User profile generation architecture for mobile content-message targeting
US9398113B2 (en) 2007-07-07 2016-07-19 Qualcomm Incorporated Methods and systems for providing targeted information using identity masking in a wireless communications device
US20090012861A1 (en) * 2007-07-07 2009-01-08 Qualcomm Incorporated Method and system for providing targeted information using profile attributes with variable confidence levels in a mobile environment
US9716764B2 (en) 2007-07-25 2017-07-25 Yahoo! Inc. Display of communication system usage statistics
US10356193B2 (en) 2007-07-25 2019-07-16 Oath Inc. Indexing and searching content behind links presented in a communication
US11394679B2 (en) 2007-07-25 2022-07-19 Verizon Patent And Licensing Inc Display of communication system usage statistics
US10554769B2 (en) 2007-07-25 2020-02-04 Oath Inc. Method and system for collecting and presenting historical communication data for a mobile device
US20090106415A1 (en) * 2007-07-25 2009-04-23 Matthew Brezina Display of Person Based Information Including Person Notes
US11552916B2 (en) 2007-07-25 2023-01-10 Verizon Patent And Licensing Inc. Indexing and searching content behind links presented in a communication
US10069924B2 (en) 2007-07-25 2018-09-04 Oath Inc. Application programming interfaces for communication systems
US9298783B2 (en) 2007-07-25 2016-03-29 Yahoo! Inc. Display of attachment based information within a messaging system
US10623510B2 (en) 2007-07-25 2020-04-14 Oath Inc. Display of person based information including person notes
US10958741B2 (en) 2007-07-25 2021-03-23 Verizon Media Inc. Method and system for collecting and presenting historical communication data
US9954963B2 (en) 2007-07-25 2018-04-24 Oath Inc. Indexing and searching content behind links presented in a communication
US9699258B2 (en) 2007-07-25 2017-07-04 Yahoo! Inc. Method and system for collecting and presenting historical communication data for a mobile device
US9275118B2 (en) 2007-07-25 2016-03-01 Yahoo! Inc. Method and system for collecting and presenting historical communication data
US20090030872A1 (en) * 2007-07-25 2009-01-29 Matthew Brezina Display of Attachment Based Information within a Messaging System
US9596308B2 (en) 2007-07-25 2017-03-14 Yahoo! Inc. Display of person based information including person notes
US9591086B2 (en) 2007-07-25 2017-03-07 Yahoo! Inc. Display of information in electronic communications
US9058366B2 (en) 2007-07-25 2015-06-16 Yahoo! Inc. Indexing and searching content behind links presented in a communication
US20090216847A1 (en) * 2007-11-14 2009-08-27 Qualcomm Incorporated Method and system for message value calculation in a mobile environment
US9203912B2 (en) 2007-11-14 2015-12-01 Qualcomm Incorporated Method and system for message value calculation in a mobile environment
US20090124241A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for user profile match indication in a mobile environment
US9705998B2 (en) * 2007-11-14 2017-07-11 Qualcomm Incorporated Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US20090125462A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US20090125321A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
US20090125585A1 (en) * 2007-11-14 2009-05-14 Qualcomm Incorporated Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
US9203911B2 (en) 2007-11-14 2015-12-01 Qualcomm Incorporated Method and system for using a cache miss state match indicator to determine user suitability of targeted content messages in a mobile environment
US8069142B2 (en) 2007-12-06 2011-11-29 Yahoo! Inc. System and method for synchronizing data on a network
US20090150507A1 (en) * 2007-12-07 2009-06-11 Yahoo! Inc. System and method for prioritizing delivery of communications via different communication channels
US8799371B2 (en) 2007-12-10 2014-08-05 Yahoo! Inc. System and method for conditional delivery of messages
US8307029B2 (en) 2007-12-10 2012-11-06 Yahoo! Inc. System and method for conditional delivery of messages
US8671154B2 (en) 2007-12-10 2014-03-11 Yahoo! Inc. System and method for contextual addressing of communications on a network
US20090157834A1 (en) * 2007-12-14 2009-06-18 Qualcomm Incorporated Method and system for multi-level distribution information cache management in a mobile environment
US9391789B2 (en) 2007-12-14 2016-07-12 Qualcomm Incorporated Method and system for multi-level distribution information cache management in a mobile environment
US8166168B2 (en) 2007-12-17 2012-04-24 Yahoo! Inc. System and method for disambiguating non-unique identifiers using information obtained from disparate communication channels
US9706345B2 (en) 2008-01-04 2017-07-11 Excalibur Ip, Llc Interest mapping system
US9626685B2 (en) 2008-01-04 2017-04-18 Excalibur Ip, Llc Systems and methods of mapping attention
US20090177644A1 (en) * 2008-01-04 2009-07-09 Ronald Martinez Systems and methods of mapping attention
US8762285B2 (en) 2008-01-06 2014-06-24 Yahoo! Inc. System and method for message clustering
US10074093B2 (en) 2008-01-16 2018-09-11 Excalibur Ip, Llc System and method for word-of-mouth advertising
US20090182631A1 (en) * 2008-01-16 2009-07-16 Yahoo! Inc. System and method for word-of-mouth advertising
US8538811B2 (en) 2008-03-03 2013-09-17 Yahoo! Inc. Method and apparatus for social network marketing with advocate referral
US8554623B2 (en) 2008-03-03 2013-10-08 Yahoo! Inc. Method and apparatus for social network marketing with consumer referral
US8560390B2 (en) 2008-03-03 2013-10-15 Yahoo! Inc. Method and apparatus for social network marketing with brand referral
US8589486B2 (en) 2008-03-28 2013-11-19 Yahoo! Inc. System and method for addressing communications
US8745133B2 (en) 2008-03-28 2014-06-03 Yahoo! Inc. System and method for optimizing the storage of data
US8271506B2 (en) 2008-03-31 2012-09-18 Yahoo! Inc. System and method for modeling relationships between entities
US8072379B2 (en) * 2008-05-12 2011-12-06 Qualcomm Incorporated GPS power savings using low power sensors
US20090278738A1 (en) * 2008-05-12 2009-11-12 Qualcomm Incorporated Gps power savings using low power sensors
US9858348B1 (en) 2008-06-27 2018-01-02 Google Inc. System and method for presentation of media related to a context
US8706406B2 (en) 2008-06-27 2014-04-22 Yahoo! Inc. System and method for determination and display of personalized distance
US20090328087A1 (en) * 2008-06-27 2009-12-31 Yahoo! Inc. System and method for location based media delivery
US8452855B2 (en) 2008-06-27 2013-05-28 Yahoo! Inc. System and method for presentation of media related to a context
US8813107B2 (en) 2008-06-27 2014-08-19 Yahoo! Inc. System and method for location based media delivery
US9158794B2 (en) 2008-06-27 2015-10-13 Google Inc. System and method for presentation of media related to a context
US8583668B2 (en) 2008-07-30 2013-11-12 Yahoo! Inc. System and method for context enhanced mapping
US10230803B2 (en) 2008-07-30 2019-03-12 Excalibur Ip, Llc System and method for improved mapping and routing
US8386506B2 (en) 2008-08-21 2013-02-26 Yahoo! Inc. System and method for context enhanced messaging
US8281027B2 (en) 2008-09-19 2012-10-02 Yahoo! Inc. System and method for distributing media related to a location
US7966325B2 (en) * 2008-09-24 2011-06-21 Yahoo! Inc. System and method for ranking search results using social information
US20100082593A1 (en) * 2008-09-24 2010-04-01 Yahoo! Inc. System and method for ranking search results using social information
US9600484B2 (en) 2008-09-30 2017-03-21 Excalibur Ip, Llc System and method for reporting and analysis of media consumption data
US8108778B2 (en) 2008-09-30 2012-01-31 Yahoo! Inc. System and method for context enhanced mapping within a user interface
US8024317B2 (en) 2008-11-18 2011-09-20 Yahoo! Inc. System and method for deriving income from URL based context queries
US8060492B2 (en) 2008-11-18 2011-11-15 Yahoo! Inc. System and method for generation of URL based context queries
US9805123B2 (en) 2008-11-18 2017-10-31 Excalibur Ip, Llc System and method for data privacy in URL based context queries
US8032508B2 (en) 2008-11-18 2011-10-04 Yahoo! Inc. System and method for URL based query for retrieving data related to a context
US9224172B2 (en) 2008-12-02 2015-12-29 Yahoo! Inc. Customizable content for distribution in social networks
US8055675B2 (en) 2008-12-05 2011-11-08 Yahoo! Inc. System and method for context based query augmentation
US8166016B2 (en) 2008-12-19 2012-04-24 Yahoo! Inc. System and method for automated service recommendations
US20100161544A1 (en) * 2008-12-23 2010-06-24 Samsung Electronics Co., Ltd. Context-based interests in computing environments and systems
US20100161381A1 (en) * 2008-12-23 2010-06-24 Samsung Electronics Co., Ltd. Semantics-based interests in computing environments and systems
US8175902B2 (en) 2008-12-23 2012-05-08 Samsung Electronics Co., Ltd. Semantics-based interests in computing environments and systems
US8554767B2 (en) 2008-12-23 2013-10-08 Samsung Electronics Co., Ltd Context-based interests in computing environments and systems
US20100198604A1 (en) * 2009-01-30 2010-08-05 Samsung Electronics Co., Ltd. Generation of concept relations
US20130059609A1 (en) * 2009-02-04 2013-03-07 Google Inc. Mobile Device Battery Management
US8150967B2 (en) 2009-03-24 2012-04-03 Yahoo! Inc. System and method for verified presence tracking
US20100299329A1 (en) * 2009-05-20 2010-11-25 Genieo Innovation Ltd. Apparatus and Methods for Providing Answers to Queries Respective of a User Based on User Uniquifiers
US8504569B2 (en) * 2009-05-20 2013-08-06 Genieo Innovation Ltd. Apparatus and methods for providing answers to queries respective of a user based on user uniquifiers
US10223701B2 (en) 2009-08-06 2019-03-05 Excalibur Ip, Llc System and method for verified monetization of commercial campaigns
US8914342B2 (en) 2009-08-12 2014-12-16 Yahoo! Inc. Personal data platform
US8364611B2 (en) 2009-08-13 2013-01-29 Yahoo! Inc. System and method for precaching information on a mobile device
US20120229340A1 (en) * 2009-12-15 2012-09-13 Paul Henry Systems and Methods for Determining Geographic Location of a Mobile Device
US9760866B2 (en) 2009-12-15 2017-09-12 Yahoo Holdings, Inc. Systems and methods to provide server side profile information
US9519065B2 (en) * 2009-12-15 2016-12-13 At&T Intellectual Property I, L.P. Systems and methods for determining geographic location of a mobile device
US11037106B2 (en) 2009-12-15 2021-06-15 Verizon Media Inc. Systems and methods to provide server side profile information
WO2011085037A1 (en) 2010-01-05 2011-07-14 Qualcomm Incorporated Method for determining the correlation between a received user profile and a stored user profile
US9842145B2 (en) 2010-02-03 2017-12-12 Yahoo Holdings, Inc. Providing profile information using servers
US9020938B2 (en) 2010-02-03 2015-04-28 Yahoo! Inc. Providing profile information using servers
US8924956B2 (en) * 2010-02-03 2014-12-30 Yahoo! Inc. Systems and methods to identify users using an automated learning process
US9842144B2 (en) 2010-02-03 2017-12-12 Yahoo Holdings, Inc. Presenting suggestions for user input based on client device characteristics
US20110191768A1 (en) * 2010-02-03 2011-08-04 Xobni Corporation Systems and Methods to Identify Users Using an Automated Learning Process
US9198133B2 (en) 2010-03-12 2015-11-24 Sunrise Micro Devices, Inc. Power efficient communications
US9241315B2 (en) 2010-03-12 2016-01-19 Sunrise Micro Devices, Inc. Power efficient communications
US9564939B2 (en) 2010-03-12 2017-02-07 Sunrise Micro Devices, Inc. Power efficient communications
US9553626B2 (en) 2010-03-12 2017-01-24 Sunrise Micro Devices, Inc. Power efficient communications
US20110222613A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US9548783B2 (en) 2010-03-12 2017-01-17 Sunrise Micro Devices, Inc. Power efficient communications
US20130035043A1 (en) * 2010-03-12 2013-02-07 Sunrise Micro Devices, Inc. Power efficient communications
US20110223874A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US20110222614A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US20110222419A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US20110222454A1 (en) * 2010-03-12 2011-09-15 Sunrise Micro Devices, Inc. Power efficient communications
US9544004B2 (en) 2010-03-12 2017-01-10 Sunrise Micro Devices, Inc. Power efficient communications
US9198134B2 (en) * 2010-03-12 2015-11-24 Sunrise Micro Devices, Inc. Power efficient communications
US9237526B2 (en) 2010-03-12 2016-01-12 Sunrise Micro Devices, Inc. Power efficient communications
US9461689B2 (en) 2010-03-12 2016-10-04 Sunrise Micro Devices, Inc. Power efficient communications
US9461688B2 (en) 2010-03-12 2016-10-04 Sunrise Micro Devices, Inc. Power efficient communications
US9134873B2 (en) * 2010-09-28 2015-09-15 Qualcomm Incorporated Apparatus and methods for presenting interaction information
US20120075264A1 (en) * 2010-09-28 2012-03-29 Kies Jonathan K Apparatus and methods for presenting interaction information
WO2012141945A1 (en) 2011-04-11 2012-10-18 Microsoft Corporation Adaptive notifications
EP2698016A1 (en) * 2011-04-11 2014-02-19 Microsoft Corporation Adaptive notifications
EP2698016A4 (en) * 2011-04-11 2014-10-01 Microsoft Corp Adaptive notifications
US9747583B2 (en) 2011-06-30 2017-08-29 Yahoo Holdings, Inc. Presenting entity profile information to a user of a computing device
US11232409B2 (en) 2011-06-30 2022-01-25 Verizon Media Inc. Presenting entity profile information to a user of a computing device
US8478768B1 (en) * 2011-12-08 2013-07-02 Palo Alto Research Center Incorporated Privacy-preserving collaborative filtering
US20130151540A1 (en) * 2011-12-08 2013-06-13 Palo Alto Research Center Incorporated Privacy-preserving collaborative filtering
US10192200B2 (en) 2012-12-04 2019-01-29 Oath Inc. Classifying a portion of user contact data into local contacts
US9571998B2 (en) * 2013-01-15 2017-02-14 Marvell World Trade Ltd. System and method for asynchronous event reporting
US20140201358A1 (en) * 2013-01-15 2014-07-17 Marvell World Trade Ltd. System and Method for Asynchronous Event Reporting
KR102424196B1 (en) 2013-08-08 2022-07-25 큐리온코리아 주식회사 Method, system and non-transitory computer-readable recording medium for extracting semantic keyword
KR20150018474A (en) * 2013-08-08 2015-02-23 큐리온코리아 주식회사 Method, system and non-transitory computer-readable recording medium for extracting semantic keyword
WO2015038899A1 (en) * 2013-09-12 2015-03-19 Upsight, Inc. Systems and methods for predicting user lifetime value using cohorts
WO2015088993A3 (en) * 2013-12-12 2015-08-13 Microsoft Technology Licensing, Llc Predicted travel intent
US9618343B2 (en) 2013-12-12 2017-04-11 Microsoft Technology Licensing, Llc Predicted travel intent
US9976864B2 (en) 2013-12-12 2018-05-22 Microsoft Technology Licensing, Llc Predicted travel intent
US11038994B2 (en) * 2016-02-10 2021-06-15 Telefonaktiebolaget Lm Ericsson (Publ) Technique for transport protocol selection and setup of a connection between a client and a server
US10791187B2 (en) 2016-04-29 2020-09-29 Beijing Xiaomi Mobile Software Co., Ltd. Information displaying method and apparatus, and storage medium
US10972557B2 (en) * 2017-01-11 2021-04-06 Google Llc Data packet transmission optimization of data used for content item selection
US10630788B2 (en) 2017-01-11 2020-04-21 Google Llc Data packet transmission optimization of data used for content item selection
US10165064B2 (en) * 2017-01-11 2018-12-25 Google Llc Data packet transmission optimization of data used for content item selection
US10436615B2 (en) 2017-04-24 2019-10-08 Carnegie Mellon University Virtual sensor system
WO2019016614A3 (en) * 2017-07-14 2019-05-02 Alibaba Group Holding Limited Method and apparatus for displaying search results
CN110113410A (en) * 2019-04-30 2019-08-09 秒针信息技术有限公司 A kind of management method, device, electronic equipment and the storage medium of information push

Also Published As

Publication number Publication date
JP2013122773A (en) 2013-06-20
CN101911618A (en) 2010-12-08
JP2011504626A (en) 2011-02-10
WO2009065052A1 (en) 2009-05-22
JP5345631B2 (en) 2013-11-20
US20090124241A1 (en) 2009-05-14
JP2011507055A (en) 2011-03-03
JP5134091B2 (en) 2013-01-30
KR101195640B1 (en) 2012-10-31
JP2011504341A (en) 2011-02-03
WO2009065060A1 (en) 2009-05-22
CN101911619B (en) 2015-09-09
CN102119513A (en) 2011-07-06
US20090125462A1 (en) 2009-05-14
CN101911617B (en) 2015-12-16
US20090216847A1 (en) 2009-08-27
JP5657712B2 (en) 2015-01-21
KR20100088623A (en) 2010-08-09
EP2225860A1 (en) 2010-09-08
US9203912B2 (en) 2015-12-01
KR101172968B1 (en) 2012-08-13
KR20100092018A (en) 2010-08-19
JP5307153B2 (en) 2013-10-02
KR101190446B1 (en) 2012-10-12
KR101134248B1 (en) 2012-06-29
WO2009065071A1 (en) 2009-05-22
CN101911618B (en) 2015-07-15
US9203911B2 (en) 2015-12-01
EP2225859A1 (en) 2010-09-08
JP2011509540A (en) 2011-03-24
JP2011504061A (en) 2011-01-27
CN101911619A (en) 2010-12-08
KR101161078B1 (en) 2012-07-13
CN102119513B (en) 2014-10-29
KR20100084690A (en) 2010-07-27
EP2223479A1 (en) 2010-09-01
KR20100087385A (en) 2010-08-04
JP5209733B2 (en) 2013-06-12
CN101911620B (en) 2014-12-24
US20090125585A1 (en) 2009-05-14
CN101911620A (en) 2010-12-08
KR20100076070A (en) 2010-07-05
EP2225861A1 (en) 2010-09-08
EP2232798A1 (en) 2010-09-29
CN101911617A (en) 2010-12-08
WO2009065064A1 (en) 2009-05-22
WO2009065067A1 (en) 2009-05-22
US9705998B2 (en) 2017-07-11

Similar Documents

Publication Publication Date Title
US9705998B2 (en) Method and system using keyword vectors and associated metrics for learning and prediction of user correlation of targeted content messages in a mobile environment
US20090125321A1 (en) Methods and systems for determining a geographic user profile to determine suitability of targeted content messages based on the profile
US9391789B2 (en) Method and system for multi-level distribution information cache management in a mobile environment

Legal Events

Date Code Title Description
AS Assignment

Owner name: QUALCOMM INCORPORATED, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KRISHNASWAMY, DILIP;VERMA, NAKUL;BYCHKOVSKY, VLADIMIR;REEL/FRAME:021844/0889;SIGNING DATES FROM 20081105 TO 20081107

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE