US20130311621A1 - Universal Communications Infrastructure - Google Patents

Universal Communications Infrastructure Download PDF

Info

Publication number
US20130311621A1
US20130311621A1 US13/986,608 US201313986608A US2013311621A1 US 20130311621 A1 US20130311621 A1 US 20130311621A1 US 201313986608 A US201313986608 A US 201313986608A US 2013311621 A1 US2013311621 A1 US 2013311621A1
Authority
US
United States
Prior art keywords
user
communication channel
communication
implementations
server system
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
US13/986,608
Inventor
Joseph Tyson
Nathan Stoll
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.)
Walmart Apollo LLC
Original Assignee
Luvocracy 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 Luvocracy Inc filed Critical Luvocracy Inc
Priority to US13/986,608 priority Critical patent/US20130311621A1/en
Priority to PCT/US2013/041714 priority patent/WO2013173799A1/en
Priority to PCT/US2013/041700 priority patent/WO2013173788A1/en
Priority to PCT/US2013/041702 priority patent/WO2013173790A1/en
Priority to PCT/US2013/041705 priority patent/WO2013173792A1/en
Assigned to Luvocracy Inc. reassignment Luvocracy Inc. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: STOLL, NATHAN, TYSON, JOSEPH
Publication of US20130311621A1 publication Critical patent/US20130311621A1/en
Assigned to WAL-MART STORES, INC. reassignment WAL-MART STORES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Luvocracy Inc.
Priority to US14/708,069 priority patent/US10346895B2/en
Assigned to WALMART APOLLO, LLC reassignment WALMART APOLLO, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: WAL-MART STORES, INC.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • 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
    • G06Q30/0207Discounts or incentives, e.g. coupons or rebates
    • G06Q30/0214Referral reward systems
    • 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/06Buying, selling or leasing transactions
    • G06Q30/0601Electronic shopping [e-shopping]
    • G06Q30/0631Item recommendations
    • 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/06Buying, selling or leasing transactions
    • G06Q30/0601Electronic shopping [e-shopping]
    • G06Q30/0633Lists, e.g. purchase orders, compilation or processing
    • G06Q30/0635Processing of requisition or of purchase orders
    • 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/06Buying, selling or leasing transactions
    • G06Q30/0601Electronic shopping [e-shopping]
    • G06Q30/0641Shopping interfaces
    • 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
    • G06Q50/00Systems or methods specially adapted for specific business sectors, e.g. utilities or tourism
    • G06Q50/01Social networking
    • 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/04Real-time or near real-time messaging, e.g. instant messaging [IM]
    • H04L51/046Interoperability with other network applications or services
    • 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/52User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail for supporting social networking 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/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • 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
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
    • 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

Definitions

  • the disclosed implementations relate to the field of online services generally and in particular to providing convenient interactions for users.
  • Online services that have emerged include, for example, online commerce services and social networking services. These services open up new experiences for user, including interactions between users and new ways of shopping for goods and services. These services incur a positive network effect as more users sign up and use the service.
  • a source of inconvenience in the user experience is the provision of information by the user to the online service in order to make full use of the service.
  • the online service asks for a certain amount of information upfront from the user at sign-up, and can subsequently ask for additional information. If the venue asks for too much information too quickly, the user is overwhelmed and becomes less likely to provide the information, less likely to stay with the service, or less likely to sign up for the service in the first place.
  • Another source of inconvenience is the communication interface between the user and the online service.
  • a user can use different modes of communication on any given day. Limiting the user to one mode of communication with the service inconveniences the user and limits the user's interaction with the service. Requesting information from the user without requesting too much too quickly, and providing multiple avenues or modes of communication with users, including avenues that has a conversational feel, make online services more convenient and user-friendly.
  • a method for requesting user data is disclosed.
  • the method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors.
  • the server system establishes a user profile for a user, the user profile including one or more information items associated with the user.
  • the server system receives a request from the user to access additional services. In response to receiving the user request, the server system requests additional information from the user.
  • a server system that requests user data.
  • the server system has one or more processors, and memory storing one or more programs to be executed by the one or more processors.
  • the one or more programs include instructions for: establishing a user profile for a user, the user profile including one or more information items associated with the user; receiving a request from the user to access additional services; and in response to receiving the user request, requesting additional information from the user.
  • a non-transitory computer readable storage medium storing one or more programs configured for execution by a server system.
  • the one or more programs also include instructions for: establishing a user profile for a user, the user profile including one or more information items associated with the user; receiving a request from the user to access additional services; and in response to receiving the user request, requesting additional information from the user.
  • a method for responding to requests submitted through a conversational interface is disclosed.
  • the method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors.
  • the server system receives a request from a user through a conversational interface.
  • the server system determines, based on the request, whether the system is able to fulfill the request automatically.
  • the server system fulfills the user request with no human interaction.
  • the server system sends the request to a human operator for fulfillment.
  • a server system responding to requests submitted through a conversational interface has one or more processors, and memory storing one or more programs to be executed by the one or more processors.
  • the one or more programs include instructions for: receiving a request from a user through a conversational interface; determining, based on the request, whether the system is able to fulfill the request automatically; in accordance with a determination that the system is able to fulfill the request automatically, fulfilling the user request with no human interaction; and in accordance with a determination that the system is not able to fulfill the request without human intervention, sending the request to a human operator for fulfillment.
  • a non-transitory computer readable storage medium storing one or more programs configured for execution by a client system.
  • the one or more programs include instructions for: receiving a request from a user through a conversational interface; determining, based on the request, whether the system is able to fulfill the request automatically; in accordance with a determination that the system is able to fulfill the request automatically, fulfilling the user request with no human interaction; and in accordance with a determination that the system is not able to fulfill the request without human intervention, sending the request to a human operator for fulfillment.
  • a method for enabling communication with a user is disclosed.
  • the method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors.
  • the server system sends communication data to a user using a first communication channel.
  • the server system determines that the user has ceased using the first communication channel for receiving communications.
  • the server system identifies a second communication channel.
  • the server system sends further communication data to the user using the identified second communication channel.
  • a server system enabling communication with a user.
  • the server system has one or more processors, and memory storing one or more programs to be executed by the one or more processors.
  • the one or more programs include instructions for: sending communication data to a user using a first communication channel; determining that the user has ceased using the first communication channel for receiving communications; identifying a second communication channel; and sending further communication data to the user using the identified second communication channel.
  • a non-transitory computer readable storage medium storing one or more programs configured for execution by a server system.
  • the one or more programs also include instructions for receiving an indication of intent from a user to purchase a good or service within a specific category.
  • the one or more programs include instructions for: sending communication data to a user using a first communication channel; determining that the user has ceased using the first communication channel for receiving communications; identifying a second communication channel; and sending further communication data to the user using the identified second communication channel.
  • FIG. 1 is a block diagram illustrating a client-server environment in accordance with some implementations.
  • FIG. 2 is a block diagram illustrating a client system in accordance with some implementations.
  • FIG. 3 is a block diagram illustrating a server system in accordance with some implementations.
  • FIG. 4 depicts a block diagram of an exemplary data structure for a user profile database for storing information related to users of the server system.
  • FIG. 5 is a flow diagram illustrating the process for requesting user data in accordance with some implementations.
  • FIG. 6 is a flow diagram illustrating the process for responding to requests submitted through a conversational interface in accordance with some implementations.
  • FIG. 7 is a flow diagram illustrating the process for enabling communication with a user in accordance with some implementations.
  • a server system operates an online service (e.g., an online commerce system).
  • the online service gradually onboards a user while progressively getting more and more data about the user.
  • the online service determines if a user request can be fulfilled automatically, and sends the request to a human operator for fulfillment if the service is unable to fulfill the request automatically.
  • the online service has multiple channels or modes of communications or interaction with the user.
  • a user can purchase goods or services, accumulate a social network of users of the online service, recommend goods or services to users of the online service, and recommend users to the online service.
  • users of the online service access these features through a web site operated by the online service or through any of multiple modes of communication with the online service (e.g., email to a specified email address).
  • the server system gradually onboards a user onto the online service while progressively getting more and more data about the user (e.g., requesting the user to provide more information).
  • the server system gets more data about the user by directly asking the user for data, extracting data from elsewhere (e.g., other social networks, publicly accessible online content), or inferring data from other data associated with the user (e.g., inferring data from data already in the user's profile).
  • the server system asks the user to verify extracted or inferred data.
  • the server system asks the user to provide or verify data gradually, such as periodically or when the data is needed to fulfill a user request, as opposed to all at once.
  • the service communicates to the user the reasons the online service is seeking the data. The user can then make an informed decision regarding whether to provide the data or not, or even to have the data removed.
  • the user signs up for the online service by providing certain information (e.g., a name and/or an email address). With that information, the server system builds a profile of the user, which then can be augmented with additional information.
  • certain information e.g., a name and/or an email address.
  • a new user signs up for the online service through initial introductory communications. For example, a first user is copied on a message sent to the online service by a second user, or a message from the first user to the second user is forwarded to the online service by the second user; the copying or the forwarding implicitly invites the first user to the online service.
  • the first user is explicitly invited to the online service by the second user (e.g., the second user submits to the online service the first user as an invitee), with the online service sending an invitation message to the first user.
  • the first user signs up for the online service by interacting with the online service (e.g., continuing to participate in the message thread that includes the copied or forwarded message, clicking on a web link in an invitation message).
  • a long-form signup process is omitted for the first user.
  • the server system extracts data about the first user that is used to sign up the first user (e.g., the user's name and/or email address).
  • the server system of the online service then has a user and at least one social relationship, since the user was invited or recommended by another user.
  • the user is gradually incorporated into more complex social networks within the online service. Any implicit introduction or encounter with another user through the service can progressively allow the user to broaden their social network within the online service. For example, the user invites other users to the online service, and the other users who sign up for the online service becomes part of the inviter user's social network within the online service.
  • the online service solicits from the user additional information, inviting the user to respond with a diverse array of data types.
  • the online service can prompt a user to provide a profile picture, or various social media user names.
  • the online service may also ask the user to verify data that were extracted or inferred by the online service (e.g., “we believe this might be a picture of you; if it is, respond Yes”).
  • the server system of the online service solicits additional information from the user when the user makes a request to access a service or feature within the online service; the online service solicits the additional information in order to fulfill the user request.
  • the online service display a dialog for direct input of the invitee's contact information, and optionally displays a dialog for authorization to access a third-party service (e.g., a social network outside of the online service).
  • the user is informed in the dialog that the authorization is needed for the online service to access the third-party service, with the benefit of that access being that the user can, for example, import data or invite users from the third-party service to the online service.
  • the user provides the information for authorization to access the third-party service, the user can specify a user in the third party service as an invitee, and the online service, optionally, links to the user the third-party service account corresponding to the authorization information.
  • the server system solicits payment information (e.g., credit card number, name on credit card, billing address, etc.) from the user in order to fulfill the purchase request.
  • payment information e.g., credit card number, name on credit card, billing address, etc.
  • the payment information is stored in the user's profile and can be used to extract or infer further information not already in the user profile.
  • the name on the credit card may be inferred to be the user's real name, and the user is asked by the online service to confirm whether that is the case.
  • the name can also be used to extract additional information (e.g., profession, social network profile, photo, etc.) from external sources (e.g., publicly available content).
  • additional information e.g., profession, social network profile, photo, etc.
  • external sources e.g., publicly available content
  • these include authorization dialogues with third party services, or conversational requests/notifications of actions to be responded to.
  • the online service makes solicitations of information from the user that are not prompted by a user request. For example, the online service periodically asks the user to verify a piece of extracted or inferred information without being prompted by a specific request by the user.
  • the solicitation of information follows a sequence that is defined by a state machine or decision tree, or the like.
  • the state machine or decision tree defines a sequence or path of information requests based on, for example, what information the online service already has for the user.
  • the online service recognizes the following data types:
  • the online service offers the same functionality offered in a “web site” through conversational channels. For example, if a user can accomplish a task on a web site, the user can also accomplish the task by communicating with the online service through any of multiple channels.
  • different users have different preferences in their modes or channels of communication with the online service.
  • Examples of the different modes or channels of communication include a web site, email, messaging (e.g., chat, instant messaging, SMS), social networking posts (e.g., Twitter tweets, status updates or comments in a social network), and voice communication (e.g., telephony).
  • the flexibility of responding to natural human language comes at a cost because of its varied and open-ended nature. User may believe that they are communicating with a human when in reality they are communicating with a computer. While many requests may be handled automatically, some must be referred to a human administrator.
  • automation can speed up response rates and eliminate errors and repetitive work.
  • the online service has a system where a user interacts directly (e.g., through a web site or a mobile app).
  • a user communicates with a human administrator.
  • these modes or channels of communication may be viewed, at a high level, as filling out forms with the information that is needed for the online service to fulfill user requests.
  • the online service knows what information is needed to fulfill a request, and attempts to get this information as quickly and easily for the user as possible.
  • the communications between the user and the online service is a conversation of sorts, and the multiple modes or channels of communication between the user and the online service, aggregately, may be viewed as a conversational interface.
  • some requests are complete (i.e., online service has the information needed to fulfill the request). For example, the information is all included in the request email or filled in a form at a web site of the online service. But some requests have missing pieces of information that needs to be obtained from the user. Other requests may be ambiguous (e.g., the communication making the request is ambiguous) and the online service needs to verify the request with the user to ensure that the request is understood correctly. In some implementations, whether a request can be fulfilled automatically by the online service without the intervention of a human administrator is based on whether the request is ambiguous and/or whether there is information needed to fulfill the request that is missing and that needs to be confirmed in-person.
  • the obtaining of information needed to complete the request or resolution of an ambiguous request is automated. For example, if a user requests to buy a shoe, but forgets to indicate a size, the online service can automatically ask for the size by sending an email, an SMS, an instant message, or direct a human administrator to call the user. If the online service can detect what is missing automatically, the conversation between the user and the online service can be carried out more quickly, in some implementations, some types of information, if missing, are be sought from the user automatically without human intervention. For example, in the above example, the online service would automatically send a message to the user to get missing shoe size. On the other hand, some types of information, if missing, are sought or confirmed by in-person communications. For example, credit card information and other sensitive information, if missing, are sought or confirmed with, for example, a phone call from a human administrator to the user.
  • the communications between the online service and the user include use of specific nomenclature that restricts the space of valid responses. This helps reduce the possibility of ambiguity in the communications.
  • information needed to fulfill a request need not be all included in the communication conveying the request.
  • the online service can retrieve information from the user's profile, if needed, to fulfill the request. For example, if the online service knows a user from previous engagements the online service may already know the user's preferred selections, for example, their shoe size. The online service may then predict that a new purchase will be of the same size, and a communication to the user is sent to verify that the online service has made the correct selection.
  • the online service adjusts the rate of its communications with the user. For example, by responding quickly when the user is actively responding, the online service increases the likelihood that the user will respond quickly again with further information. But if the user is responding slowly (e.g., time duration between responses above a certain threshold), the online service can assume the user has stepped away from their device and will wait longer before following up further.
  • any incoming communications from the user to the online service is sent to a specified email address.
  • a communication sent to the specified email address can be about anything a user wants to communicate to the online service, and on the receiving end, the online service processes the communication automatically or with a human administrator, depending on the nature of the communication.
  • the online service automatically makes a best guess of what type a communication belongs to based on features in the communication that are extractable by the online service.
  • the context of the email in view of the conversation the email belongs to is known. It is more difficult with a communication initiated by a user.
  • possible types of incoming messages, that are not replies include:
  • the online service has algorithms for the disambiguation of incoming messages. Some are rule-based but others may use machine learning techniques.
  • the online service follows a process of responding to and handling the message type as if the request in the message had been submitted/taken as an action on a web site of the online service.
  • the online service allows its users to communicate with the online service and convey requests using natural language and a predefined structure for processing the communications.
  • the structure has, for example, one or more rules for processing communications from users and determining how to proceed.
  • a rule may be that a reply with a specific term conveys a specific type of request.
  • Another rule may be that certain terms are known to be ambiguous, and thus trigger follow-ups for clarification (e.g., follow-up communication soliciting clarification or even human intervention).
  • the online service may be considered to be a conversational interface.
  • conversational interfaces are like language oriented state machines, where the states may require very specific structure, or very broad interpretation (e.g., replying “buy” to a tweet kicks off a state flow that results in a purchase).
  • the state flow through the state machine of the conversational interface can be linear or interleaving; just as one can explore a website linearly (e.g., by referencing a sitemap) or in a path-dependent manner where the next page to visit is based on what is in the current page, communications in a conversational interface can have similar properties—a linear flow or an interleaving flow.
  • multiple channels or modes of communication are available for communications between users and the online service.
  • the user can switch modes. For example, the user starts out sending email to the online service, and then switches to instant messaging.
  • the online service detects the change and switches to match the communication channel used by the user.
  • internal services within the online service communicate with a single interface by specifying a target user combined with a payload of metadata pertaining to the outbound message.
  • the interface receiving this information identifies a set of possible channels for the target user by calling a set of classification services. Once a channel has been identified, it is stored and used for all further communication.
  • FIG. 1 is a block diagram illustrating a client-server environment 100 in accordance with some implementations.
  • the client-server environment 100 includes one or more client systems 102 - 1 and 102 - 2 , a server system 120 , and one or more vendors 160 , all connected over a network 110 .
  • the client system 102 includes one or more client applications 104 and a display 106 .
  • the server system 120 includes a user communication module 128 , an information gathering module 124 , a request processing module 126 , and a user profile database 130 .
  • the network 110 may consist of any one or more of any of a variety of networks, including local area networks (LAN), wide area networks (WAN), wireless networks, wired networks, the Internet, or any combination of such networks.
  • the client system 102 includes one or more client applications 104 .
  • the one or more client applications 104 include, but are not limited to, a web browsing application for connecting to the server system 120 .
  • the client system 102 also includes a display 106 .
  • the client system is a computing device with the display integrated directly the device itself, such as a laptop, a smart phone, and a tablet computer.
  • the display is connected to, but not integrated into the client system. For example, desktop computer systems often do not have an integrated display and instead connect to a standalone display.
  • the client system 102 sends communications to and receives communications form the server system 120 over any viable communication medium.
  • a communication can be transmitted via e-mail, text, voice mail, social media message, an instant message, a message through a messaging service internal to the server system, or through the messaging service of another web service or web site.
  • the client system 102 when the user of the client system 102 replies to a communication from the server system 120 , the client system 102 sends the response to the server system 120 via the same communication method that was used to send the replied-to communication. For example, if the original communication was received through an email message, the client system then uses the email messaging system to send a response. In some implementations, the client system 102 uses a different communication method to send a response. For example, the original communication is sent as an instant message through a chat program. Instead of responding through the chat program, the user sends a response via an email.
  • the server system 120 includes a user communication module 128 , an information gathering module 124 , a request processing module 126 , and a user profile database 130 .
  • the user communication module 128 is configured to send and receive communications with a user, through any communication channel the user selects.
  • the user communications module 128 also determines the user's selected communication channel if the user leaves the previous communication channel, receives requests from users, and receives indication from a user that they are changing their current communication channel.
  • the user communication module 128 determines the communication method based on past communications with the user of the client system. Thus, the user communication module 128 chooses the communication method that the user of the client system 102 uses most often when communicating with the server system. For example, if a user communicates with the server system 120 through email in 75% of communications, the server system 120 will use an email messaging system to communicate with the user. In some implementations, each user selects a preferred communication method and this preference is stored in the user profile database 130 . For example, a user selects text messaging as the preferred method for receiving messages and in response the user communication module 128 will then use text messages to send communications to the user, unless directed otherwise. In some implementations, the user communication module 128 will use multiple communication methods to send communications to the user.
  • the user communication module 128 chooses the communication method based on the time and date that the communication is to be sent. For example, the user communication module 128 uses email messages to deliver communications during the standard workday (9 am-5 pm Monday through Friday) and uses text messages to deliver communications on the weekend and evenings. In some implementations, no communications will be sent during typical sleeping hours. In some implementations, each user selects time and data preferences for the user communication module 128 to use and these preferences are stored in the user profile database 130 .
  • the user communication module 128 receives responses from client systems 102 .
  • each response is transmitted to the request processing module 126 .
  • each response is transmitted to the information gathering module 124 before it is transmitted to the request processing module 126 .
  • a copy of the response is transmitted to both to the information gathering module 124 and the request processing module 126 .
  • the request processing module 126 receives a request from a user and determining whether the server system 120 can automatically respond to the request without human interaction, and if not, forward the request to a human operator for fulfillment. In some implementations, the request processing module 126 identifies the type of request, identifies the information needed to fulfill the request, and determines whether the server system 120 has the information needed to fulfill the request.
  • the information gathering module 124 gathers and collects data associated with users.
  • the gathering and collecting of data include asking the user to provide or confirm data, crawling and extracting data from content hosts 160 , and analyzing the user profile database 130 to infer additional data.
  • asking of users to provide or confirm data is gradual (e.g., periodic) and/or responsive to user requests.
  • the user profile database 130 contains user profiles for users who have registered to use the service provided by the server system 120 .
  • a user profile includes the name, ID, demographic information (gender, age, location, etc), purchasing history, social network information (including username and passwords for one or more social networking sites), and trust information.
  • the user profile includes contact information submitted by the user or stored by the system after contact by the user including but not limited to email addresses, phone numbers, user names, instant message user IDs, and social networking sites user information sufficient to allow the service to access each of the user's social networking sites.
  • the user communication module 128 uses information stored in the user profile database 130 to send communications to the client system 102 .
  • the content hosts 160 host content external to the server system 120 .
  • Examples of content host(s) include web sites, social networks, and so on.
  • the information gathering module 124 crawls the content host(s) 160 to gather information associated with users of the server system 120 . The crawled information is presented to the respective users for confirmation, and information that is confirmed are stored in the user profile database 130 .
  • FIG. 2 is a block diagram illustrating a client system 102 , in accordance with some implementations.
  • the client system 102 typically includes one or more processing units (CPUs) 202 , one or more network interfaces 210 , memory 212 , and one or more communication buses 214 for interconnecting these components.
  • the client system 102 includes a user interface 204 .
  • the user interface 204 includes an associated display device 106 and optionally includes an input means such as a keyboard, mouse, a touch sensitive display, or other input buttons 208 .
  • the display device 106 includes an audio device or other information delivery device.
  • some client systems use a microphone and voice recognition to supplement or replace the keyboard.
  • Memory 212 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 212 may optionally include one or more storage devices remotely located from the CPU(s) 202 . Memory 212 , or alternately the non-volatile memory device(s) within memory 212 , includes a non-transitory computer readable storage medium. In some implementations, memory 212 or the computer readable storage medium of memory 212 stores the following programs, modules and data structures, or a subset thereof:
  • FIG. 3 is a block diagram illustrating a server system 120 , in accordance with some implementations.
  • the server system 120 typically includes one or more processing units (CPUs) 302 , one or more network interfaces 304 , memory 306 , and one or more communication buses 308 for interconnecting these components.
  • CPUs processing units
  • network interfaces 304 one or more network interfaces 304
  • memory 306 one or more communication buses 308 for interconnecting these components.
  • Memory 306 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 306 may optionally include one or more storage devices remotely located from the CPU(s) 302 . Memory 306 , or alternately the non-volatile memory device(s) within memory 306 , includes a non-transitory computer readable storage medium. In some implementations, memory 306 or the computer readable storage medium of memory 306 stores the following programs, modules and data structures, or a subset thereof:
  • FIG. 4 depicts a block diagram of an exemplary data structure for a user profile database 130 for storing information related to users of the server system ( FIG. 1 , 120 ).
  • the user profile database 130 includes a plurality of user profiles 402 - 1 to 402 -P, each of which corresponds to a user registered with the server system ( FIG. 1 , 120 ).
  • each user profile 402 contains a user profile ID 404 , a user history 406 , trust information 408 , recommendations 410 made by the user, and user contact information 412 .
  • user profile ID 404 is a value that uniquely identifies a specific user of the server system ( FIG. 1 , 120 ). In some implementations, this value is chosen by the user and is a user name. In other implementations, this value is assigned to the user by the server system ( FIG. 1 , 120 ) as part of the registration process.
  • the user history 406 stores a history of the user's past interactions with the server system ( FIG. 1 , 120 ) including past user purchases, searches, page views, previous product recommendations, previous product reviews, and social connections of the user including previously recorded trust information for other users and/or social information received from social networking sites.
  • trust information 408 includes data describing the social connections of the user and includes a trust level for other users of the server system ( FIG. 1 , 120 ).
  • a trust level is a value representing the degree to which a user trusts the opinions and recommendations of another user.
  • trust information is explicitly submitted by the users, in other situations the server system ( FIG. 1 , 120 ) infers trust information from the actions of users, and in yet other situations trust information includes information from both user submissions and server inferences.
  • recommendation 410 data includes product purchases and product recommendations previously submitted by the user.
  • contact information 412 includes a list of contact information for contacting the user through a plurality of communication methods and information describing if and when the server system ( FIG. 1 , 120 ) should use that method.
  • the contact information 412 includes an email address, a phone number, and a social network ID for the user. The user may select that the server system ( FIG. 1 , 120 ) should never use social network messaging to contact to user and should use email address at all times except for the weekend and that a text message to a mobile phone should be used on the weekend.
  • the contact information 412 includes login and password information for one or more social networking sites.
  • FIG. 5 is a flow diagram illustrating the process for requesting user data in accordance with some implementations.
  • Each of the operations shown in FIG. 5 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders).
  • the method described in FIG. 5 is performed by the server system ( FIG. 1 , 120 ).
  • the server system ( FIG. 1 , 120 ) establishing a user profile ( FIG. 4 , 402 ) for a user ( 502 ).
  • the user profile 402 includes one or more information items associated with the user (e.g., user history 406 , contact information 412 , etc.).
  • the user profile is established when the user signs up for the online service that the server system 120 operates.
  • the server system receives a request from the user to access additional services ( 504 ). For example, the server system 120 receives a communication from the user to recommend another user, recommend a good or service, or to purchase a good or service.
  • the server system in response to receiving the user request, the server system ( FIG. 1 , 120 ) requesting additional information from the user ( 506 ). For example, if the request is a product recommendation, the server system 120 can ask the user to identify a user, within or without the online service that the server system 120 operates, that referred a product to the user making the request. In some implementations, requesting additional information from the user includes requesting information needed to fulfill the user request ( 508 ). For example, if the request is a request to purchase a good, the server system 120 sends communications to the user requesting that the user provide any information that is needed to make the purchase transaction but are not in the server system 120 .
  • requesting additional information from the user includes requesting that the user confirm information associated with the user obtained from an information source.
  • the server system 120 extracts information associated with the user that is obtained from a content host 160 (e.g., a third-party social network), and server system 120 asks the user to confirm the extracted information. For example, if the request is a product recommendation, the server system 120 can extract information about the product from content hosts 160 and asks the user to confirm the information. As another example, if the request is a purchase request, the server system 120 can look in the user profile database 130 for the user's past transactions, extract information from the past transactions that is relevant to the request, and ask the user to confirm that the extracted information is still valid.
  • the information source is, for example, an online presence of the user, social network activity of the user, a communications history of the user, or a requests history of the user.
  • requesting additional information from the user includes requesting additional information from the user in accordance with a predefined information request sequence.
  • the sequence can be defined, for example, by a state diagram, decision tree, or the like.
  • the location and path within the state diagram or decision tree is based on, for example, how much and what information is in the user profile, if the user is making a request, and the type of request, if any.
  • the server system 120 periodically makes unprompted requests for additional information from the user ( 508 ). For example, the server system 120 periodically presents a solicitation of information to the user. The solicitation is not prompted by a specific user request. In some implementations, the unprompted requests are dictated by the state diagram or decision tree described above based on what information is already in the user profile.
  • the server system 120 receives the requested additional information from the user ( 510 ), and adds the received additional information to the user profile of the user ( 512 ). In some implementations, the server system 120 infers information associated with the user based on the received information ( 514 ), and adds the inferred information to the user profile of the user ( 516 ).
  • FIG. 6 is a flow diagram illustrating the process for of responding to requests submitted through a conversational interface in accordance with some implementations.
  • Each of the operations shown in FIG. 6 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders).
  • the method described in FIG. 6 is performed by the server system ( FIG. 1 , 120 ).
  • the server system receives a request from a user through a conversational interface ( 602 ).
  • the server system determines, based on the request, whether the system is able to fulfill the request automatically ( 604 ).
  • the server system 120 and a user of the client system 102 exchange communications, in which the user conveys a request (e.g., a purchase, a recommendation, etc.) and the server system 120 receives the communications and determines the type of request the user is conveying and whether fulfillment of the request can be performed automatically, without human intervention.
  • a request e.g., a purchase, a recommendation, etc.
  • determining whether the system is able to fulfill the request automatically includes, in accordance with a determination that a type of the request is ambiguous based on contents of the request, determining that the system is not able to fulfill the request without human intervention. For example, if the communication conveying the request has ambiguity (e.g., ambiguity regarding the type of request, ambiguity regarding information needed to fulfill the request), the request is determined to require human intervention for fulfillment.
  • ambiguity e.g., ambiguity regarding the type of request, ambiguity regarding information needed to fulfill the request
  • determining whether the system is able to fulfill the request automatically includes, in accordance with a determination that one or more information items needed to fulfill the request requires in-person confirmation by the user, determining that the system is not able to fulfill the request without human intervention. For example, if the information needed for fulfilling the request includes sensitive information that is not already in the user profile, the server system 120 determines that the request requires a human administrator to communicate to the user in person (e.g., by phone, by video conference) to obtain and/or confirm the sensitive information.
  • the server system 120 fulfills the user request with no human interaction ( 606 ). For example, if the request is unambiguous and the server system 120 has all of the information needed to fulfill the request, the server system 120 fulfills the request without forwarding the request to a human administrator for fulfillment.
  • the server system 120 sends the request to a human operator for fulfillment ( 608 ).
  • FIG. 7 is a flow diagram illustrating the process for enabling communication with a user in accordance with some implementations.
  • Each of the operations shown in FIG. 7 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders).
  • the method described in FIG. 7 is performed by the server system ( FIG. 1 , 120 ).
  • the server system ( FIG. 1 , 120 ), sends communication data to a user using a first communication channel ( 702 ).
  • the server system 120 determines that the user has ceased using the first communication channel for receiving communications ( 704 ).
  • the server system 120 identifies a second communication channel currently being used by the user ( 706 ).
  • the server system 120 sends further communication data to the user using the identified second communication channel ( 708 ).
  • the server system 120 sends a communication to the user at the client system 102 using, for example, instant messaging.
  • the server system 120 determines that the user has ceased using instant messaging.
  • the server system 120 identifies another communication channel (e.g., email), and sends future communications to the user using that another communication channel.
  • the first or the second communication channel is any of: email, chat messaging, text messaging, social networking, a website, message boards, voice communication (e.g., telephony, voicemail, voice over Internet Protocol, etc.), and video conferencing.
  • determining that the user has ceased using the first communication channel for receiving communication includes receiving a communication from the user on a communication channel different from the first communication channel.
  • identifying the second communication channel includes identifying the communication channel at which the communication was received as the second communication channel. For example, if the server system 120 sends a communication to the user using the first communication channel and the user replies back using a communication channel different from the first communication channel, the server system 120 determines that the user has ceased using the first communication channel and has switched to a different communication channel. That different communication channel is identified as the second communication channel.
  • determining that the user has ceased using the first communication channel receiving communication includes determining, in accordance with a schedule, that the user desires to receive communication at a communication channel different from the first communication channel.
  • identifying the second communication channel includes identifying the second communication channel in accordance with the schedule.
  • the user profile for a user may have data specifying a schedule when particular communications channels are preferred.
  • such a schedule may be predefined system-wide behavior for the server system 120 .
  • the user's preferred communication channel for receiving communication changes with the time of day in accordance with the schedule, and the second communication channel is determined in accordance with the schedule as well.
  • determining that the user has ceased using the first communication channel receiving communication includes detecting a log-out by the user from the first communication channel. For example, if the server system 120 and the user is communicating through a channel within the system (e.g., instant messaging in a web site operated by the server system 120 ) and the user logs out from the channel (e.g., the user logs out from the web site), the server system 120 determines that the user has cease using the channel within the system for communications and proceeds to switch to another channel (e.g., email).
  • a channel within the system e.g., instant messaging in a web site operated by the server system 120
  • the server system 120 determines that the user has cease using the channel within the system for communications and proceeds to switch to another channel (e.g., email).
  • first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another.
  • a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the present implementations.
  • the first contact and the second contact are both contacts, but they are not the same contact.
  • the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context.
  • the phrase “if it is determined” or “if (a stated condition or event) is detected” may be construed to mean “upon determining” or “in response to determining” or “upon detecting (the stated condition or event)” or “in response to detecting (the stated condition or event),” depending on the context.

Abstract

In accordance with some implementations, a method for enabling communication with a user is disclosed. The method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors. The server system sends communication data to a user using a first communication channel. The server system determines that the user has ceased using the first communication channel for receiving communications. The server system identifies a second communication channel. The server system sends further communication data to the user using the identified second communication channel.

Description

    RELATED APPLICATIONS
  • This application is claims priority to the following (1) U.S. Provisional Application Ser. No. 61/648,564, filed May 17, 2012, entitled “Progressively Asking for Increasing Amounts of User and Network Data”; (2) U.S. Provisional Application Ser. No. 61/648,566, filed May 17, 2012, entitled “Conversational Interfaces”; (3) U.S. Provisional Application Ser. No. 61/648,569, filed May 17, 2012, entitled “Universal Communications Infrastructure”; (4) U.S. Provisional Application Ser. No. 61/648,578, filed May 17, 2012, entitled “Trust Graph”; (5) U.S. Provisional Application Ser. No. 61/648,582, filed May 17, 2012, entitled “Universal Consumption Service”; (6) U.S. Provisional Application Ser. No. 61/648,588, filed May 17, 2012, entitled “Reward Structures”; (7) U.S. Provisional Application Ser. No. 61/648,591, filed May 17, 2012, entitled “System and Method for Social Network Based Referrals”; (8) U.S. Provisional Application Ser. No. 61/688,655, filed May 18, 2012, entitled “System and Method for Social Network Based Referrals”; which are incorporated herein by reference in their entirety.
  • This application is also related to the following (1) U.S. application Ser. No. ______, filed ______, entitled “Progressively Asking for Increasing Amounts of User and Network Data” (Attorney Docket: 020610-5001); (2) U.S. application Ser. No. ______, filed ______, entitled “Conversational Interfaces” (Attorney Docket: 020610-5002); (3) U.S. application Ser. No. 13/769,181, filed Feb. 15, 2013, entitled “Trust Graph”; (4) U.S. application Ser. No. ______, filed ______, entitled “Zero Click Commerce Systems” (Attorney Docket: 020610-5005); (5) U.S. application Ser. No. ______, filed ______, entitled “Universal Consumption Service” (Attorney Docket: 020610-5006); (6) U.S. application Ser. No. ______, filed ______, entitled “Reward Structures” (Attorney Docket: 020610-5007); (7) U.S. application Ser. No. ______, filed ______, entitled “Pre-Establishing Purchasing Intent for Computer Based Commerce Systems” entitled “System and Method for Social Network Based Referrals” (Attorney Docket: 020610-5009); which are incorporated herein by reference in their entirety.
  • TECHNICAL FIELD
  • The disclosed implementations relate to the field of online services generally and in particular to providing convenient interactions for users.
  • BACKGROUND
  • Over the last two decades, the number of online services has increased dramatically. Online services that have emerged include, for example, online commerce services and social networking services. These services open up new experiences for user, including interactions between users and new ways of shopping for goods and services. These services incur a positive network effect as more users sign up and use the service.
  • A source of inconvenience in the user experience is the provision of information by the user to the online service in order to make full use of the service. The online service asks for a certain amount of information upfront from the user at sign-up, and can subsequently ask for additional information. If the venue asks for too much information too quickly, the user is overwhelmed and becomes less likely to provide the information, less likely to stay with the service, or less likely to sign up for the service in the first place. Another source of inconvenience is the communication interface between the user and the online service. A user can use different modes of communication on any given day. Limiting the user to one mode of communication with the service inconveniences the user and limits the user's interaction with the service. Requesting information from the user without requesting too much too quickly, and providing multiple avenues or modes of communication with users, including avenues that has a conversational feel, make online services more convenient and user-friendly.
  • SUMMARY
  • In accordance with some implementations, a method for requesting user data is disclosed. The method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors. The server system establishes a user profile for a user, the user profile including one or more information items associated with the user. The server system receives a request from the user to access additional services. In response to receiving the user request, the server system requests additional information from the user.
  • In accordance with some implementations, a server system that requests user data is disclosed. The server system has one or more processors, and memory storing one or more programs to be executed by the one or more processors. The one or more programs include instructions for: establishing a user profile for a user, the user profile including one or more information items associated with the user; receiving a request from the user to access additional services; and in response to receiving the user request, requesting additional information from the user.
  • In accordance with some implementations, a non-transitory computer readable storage medium storing one or more programs configured for execution by a server system is disclosed. The one or more programs also include instructions for: establishing a user profile for a user, the user profile including one or more information items associated with the user; receiving a request from the user to access additional services; and in response to receiving the user request, requesting additional information from the user.
  • In accordance with some implementations, a method for responding to requests submitted through a conversational interface is disclosed. The method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors. The server system receives a request from a user through a conversational interface. The server system determines, based on the request, whether the system is able to fulfill the request automatically. In accordance with a determination that the system is able to fulfill the request automatically, the server system fulfills the user request with no human interaction. In accordance with a determination that the system is not able to fulfill the request without human intervention, the server system sends the request to a human operator for fulfillment.
  • In accordance with some implementations, a server system responding to requests submitted through a conversational interface is disclosed. The server system has one or more processors, and memory storing one or more programs to be executed by the one or more processors. The one or more programs include instructions for: receiving a request from a user through a conversational interface; determining, based on the request, whether the system is able to fulfill the request automatically; in accordance with a determination that the system is able to fulfill the request automatically, fulfilling the user request with no human interaction; and in accordance with a determination that the system is not able to fulfill the request without human intervention, sending the request to a human operator for fulfillment.
  • In accordance with some implementations, a non-transitory computer readable storage medium storing one or more programs configured for execution by a client system is disclosed. The one or more programs include instructions for: receiving a request from a user through a conversational interface; determining, based on the request, whether the system is able to fulfill the request automatically; in accordance with a determination that the system is able to fulfill the request automatically, fulfilling the user request with no human interaction; and in accordance with a determination that the system is not able to fulfill the request without human intervention, sending the request to a human operator for fulfillment.
  • In accordance with some implementations, a method for enabling communication with a user is disclosed. The method is performed on a server system having one or more processors and memory storing one or more programs for execution by the one or more processors. The server system sends communication data to a user using a first communication channel. The server system determines that the user has ceased using the first communication channel for receiving communications. The server system identifies a second communication channel. The server system sends further communication data to the user using the identified second communication channel.
  • In accordance with some implementations, a server system enabling communication with a user is disclosed. The server system has one or more processors, and memory storing one or more programs to be executed by the one or more processors. The one or more programs include instructions for: sending communication data to a user using a first communication channel; determining that the user has ceased using the first communication channel for receiving communications; identifying a second communication channel; and sending further communication data to the user using the identified second communication channel.
  • In accordance with some implementations, a non-transitory computer readable storage medium storing one or more programs configured for execution by a server system is disclosed. The one or more programs also include instructions for receiving an indication of intent from a user to purchase a good or service within a specific category. The one or more programs include instructions for: sending communication data to a user using a first communication channel; determining that the user has ceased using the first communication channel for receiving communications; identifying a second communication channel; and sending further communication data to the user using the identified second communication channel.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram illustrating a client-server environment in accordance with some implementations.
  • FIG. 2 is a block diagram illustrating a client system in accordance with some implementations.
  • FIG. 3 is a block diagram illustrating a server system in accordance with some implementations.
  • FIG. 4 depicts a block diagram of an exemplary data structure for a user profile database for storing information related to users of the server system.
  • FIG. 5 is a flow diagram illustrating the process for requesting user data in accordance with some implementations.
  • FIG. 6 is a flow diagram illustrating the process for responding to requests submitted through a conversational interface in accordance with some implementations.
  • FIG. 7 is a flow diagram illustrating the process for enabling communication with a user in accordance with some implementations.
  • Like reference numerals refer to corresponding parts throughout the drawings.
  • DESCRIPTION OF IMPLEMENTATIONS
  • In some implementations, a server system operates an online service (e.g., an online commerce system). In some implementations, the online service gradually onboards a user while progressively getting more and more data about the user. In some implementations, the online service determines if a user request can be fulfilled automatically, and sends the request to a human operator for fulfillment if the service is unable to fulfill the request automatically. In some implementations, the online service has multiple channels or modes of communications or interaction with the user.
  • In some implementations, where the online service is an online commerce system, a user can purchase goods or services, accumulate a social network of users of the online service, recommend goods or services to users of the online service, and recommend users to the online service. In some implementations, users of the online service access these features through a web site operated by the online service or through any of multiple modes of communication with the online service (e.g., email to a specified email address).
  • In some implementations, the server system gradually onboards a user onto the online service while progressively getting more and more data about the user (e.g., requesting the user to provide more information). In some implementations, the server system gets more data about the user by directly asking the user for data, extracting data from elsewhere (e.g., other social networks, publicly accessible online content), or inferring data from other data associated with the user (e.g., inferring data from data already in the user's profile). In some implementations, the server system asks the user to verify extracted or inferred data. In some implementations, the server system asks the user to provide or verify data gradually, such as periodically or when the data is needed to fulfill a user request, as opposed to all at once. The service communicates to the user the reasons the online service is seeking the data. The user can then make an informed decision regarding whether to provide the data or not, or even to have the data removed.
  • In some implementations, the user signs up for the online service by providing certain information (e.g., a name and/or an email address). With that information, the server system builds a profile of the user, which then can be augmented with additional information.
  • In some implementations, a new user signs up for the online service through initial introductory communications. For example, a first user is copied on a message sent to the online service by a second user, or a message from the first user to the second user is forwarded to the online service by the second user; the copying or the forwarding implicitly invites the first user to the online service. As another example, the first user is explicitly invited to the online service by the second user (e.g., the second user submits to the online service the first user as an invitee), with the online service sending an invitation message to the first user. The first user signs up for the online service by interacting with the online service (e.g., continuing to participate in the message thread that includes the copied or forwarded message, clicking on a web link in an invitation message). In some implementations, a long-form signup process is omitted for the first user. From the copied or forwarded message, or the invitation from the second user, the server system extracts data about the first user that is used to sign up the first user (e.g., the user's name and/or email address).
  • In some implementations, the server system of the online service then has a user and at least one social relationship, since the user was invited or recommended by another user. The user is gradually incorporated into more complex social networks within the online service. Any implicit introduction or encounter with another user through the service can progressively allow the user to broaden their social network within the online service. For example, the user invites other users to the online service, and the other users who sign up for the online service becomes part of the inviter user's social network within the online service.
  • In some implementations, the online service solicits from the user additional information, inviting the user to respond with a diverse array of data types. For example, the online service can prompt a user to provide a profile picture, or various social media user names. The online service may also ask the user to verify data that were extracted or inferred by the online service (e.g., “we believe this might be a picture of you; if it is, respond Yes”).
  • In some implementations, the server system of the online service solicits additional information from the user when the user makes a request to access a service or feature within the online service; the online service solicits the additional information in order to fulfill the user request. For example, when the user invites (e.g., recommends a product to) another user to the online service, the online service display a dialog for direct input of the invitee's contact information, and optionally displays a dialog for authorization to access a third-party service (e.g., a social network outside of the online service). The user is informed in the dialog that the authorization is needed for the online service to access the third-party service, with the benefit of that access being that the user can, for example, import data or invite users from the third-party service to the online service. If the user provides the information for authorization to access the third-party service, the user can specify a user in the third party service as an invitee, and the online service, optionally, links to the user the third-party service account corresponding to the authorization information.
  • As another example, when the user makes a request within the online service to purchase a good or service, if the user's profile does not already include payment information, the server system solicits payment information (e.g., credit card number, name on credit card, billing address, etc.) from the user in order to fulfill the purchase request.
  • Continuing with the payment information example, the payment information is stored in the user's profile and can be used to extract or infer further information not already in the user profile. For example, the name on the credit card may be inferred to be the user's real name, and the user is asked by the online service to confirm whether that is the case. The name can also be used to extract additional information (e.g., profession, social network profile, photo, etc.) from external sources (e.g., publicly available content). Upon confirmation by the user, the extracted or inferred information is added to the user profile.
  • As a user encounters various features in our system, this will trigger requests for additional information. In some implementations, these include authorization dialogues with third party services, or conversational requests/notifications of actions to be responded to.
  • In some implementations, the online service makes solicitations of information from the user that are not prompted by a user request. For example, the online service periodically asks the user to verify a piece of extracted or inferred information without being prompted by a specific request by the user.
  • In some implementations, the solicitation of information follows a sequence that is defined by a state machine or decision tree, or the like. The state machine or decision tree defines a sequence or path of information requests based on, for example, what information the online service already has for the user.
  • In some embodiments, the online service recognizes the following data types:
  • Email;
  • Real user name;
  • Email addresses of friends;
  • Names of friends;
  • Interests;
  • Trusted friends by category;
  • Demographic information;
  • Gender;
  • Family/Relationship situation;
  • Age;
  • Education/Occupation;
  • Location;
  • Address;
  • Credit Card;
  • Phone;
  • Pictures;
  • Social network accounts;
  • Activity history;
  • Communications; and
  • Recommendations sent.
  • In some implementations, the online service offers the same functionality offered in a “web site” through conversational channels. For example, if a user can accomplish a task on a web site, the user can also accomplish the task by communicating with the online service through any of multiple channels.
  • In some implementations, different users have different preferences in their modes or channels of communication with the online service. Examples of the different modes or channels of communication include a web site, email, messaging (e.g., chat, instant messaging, SMS), social networking posts (e.g., Twitter tweets, status updates or comments in a social network), and voice communication (e.g., telephony).
  • In some implementations, the flexibility of responding to natural human language comes at a cost because of its varied and open-ended nature. User may believe that they are communicating with a human when in reality they are communicating with a computer. While many requests may be handled automatically, some must be referred to a human administrator.
  • In some implementations, automation can speed up response rates and eliminate errors and repetitive work. At one end of the automation scale, the online service has a system where a user interacts directly (e.g., through a web site or a mobile app). At the other end, a user communicates with a human administrator. In between, there are other types of communication. These modes or channels of communication may be viewed, at a high level, as filling out forms with the information that is needed for the online service to fulfill user requests. The online service knows what information is needed to fulfill a request, and attempts to get this information as quickly and easily for the user as possible. Thus, the communications between the user and the online service is a conversation of sorts, and the multiple modes or channels of communication between the user and the online service, aggregately, may be viewed as a conversational interface.
  • In some implementations, some requests are complete (i.e., online service has the information needed to fulfill the request). For example, the information is all included in the request email or filled in a form at a web site of the online service. But some requests have missing pieces of information that needs to be obtained from the user. Other requests may be ambiguous (e.g., the communication making the request is ambiguous) and the online service needs to verify the request with the user to ensure that the request is understood correctly. In some implementations, whether a request can be fulfilled automatically by the online service without the intervention of a human administrator is based on whether the request is ambiguous and/or whether there is information needed to fulfill the request that is missing and that needs to be confirmed in-person.
  • In some implementations, the obtaining of information needed to complete the request or resolution of an ambiguous request is automated. For example, if a user requests to buy a shoe, but forgets to indicate a size, the online service can automatically ask for the size by sending an email, an SMS, an instant message, or direct a human administrator to call the user. If the online service can detect what is missing automatically, the conversation between the user and the online service can be carried out more quickly, in some implementations, some types of information, if missing, are be sought from the user automatically without human intervention. For example, in the above example, the online service would automatically send a message to the user to get missing shoe size. On the other hand, some types of information, if missing, are sought or confirmed by in-person communications. For example, credit card information and other sensitive information, if missing, are sought or confirmed with, for example, a phone call from a human administrator to the user.
  • In some implementations, the communications between the online service and the user include use of specific nomenclature that restricts the space of valid responses. This helps reduce the possibility of ambiguity in the communications.
  • In some implementations, information needed to fulfill a request need not be all included in the communication conveying the request. For example, the online service can retrieve information from the user's profile, if needed, to fulfill the request. For example, if the online service knows a user from previous engagements the online service may already know the user's preferred selections, for example, their shoe size. The online service may then predict that a new purchase will be of the same size, and a communication to the user is sent to verify that the online service has made the correct selection.
  • In some implementations, the online service adjusts the rate of its communications with the user. For example, by responding quickly when the user is actively responding, the online service increases the likelihood that the user will respond quickly again with further information. But if the user is responding slowly (e.g., time duration between responses above a certain threshold), the online service can assume the user has stepped away from their device and will wait longer before following up further.
  • In some implementations, any incoming communications from the user to the online service is sent to a specified email address. A communication sent to the specified email address can be about anything a user wants to communicate to the online service, and on the receiving end, the online service processes the communication automatically or with a human administrator, depending on the nature of the communication.
  • In some implementations, because of the open-ended nature of communication, the online service automatically makes a best guess of what type a communication belongs to based on features in the communication that are extractable by the online service. When an incoming email is a reply to earlier messages, the context of the email in view of the conversation the email belongs to is known. It is more difficult with a communication initiated by a user.
  • In some implementations, in an online service that is an online commerce system, possible types of incoming messages, that are not replies, include:
  • Recommendation. The user wants to:
      • Recommend a product or service in general, also known as a product submission;
      • Recommend a product or service to another user, a product recommendation;
      • Request a recommendation in a category; the user wants a suggestion of what to buy from her social network within the online service;
      • Purchase. The user would like to buy a specified product;
      • Nomination. The user would like to nominate a user as somebody they trust in a category;
      • Other. All other email;
  • Invitation responses;
  • Feedback and suggestions;
  • Returns;
  • Problems that need attention; and
  • Spam and other irrelevant messages.
  • In some implementations, the online service has algorithms for the disambiguation of incoming messages. Some are rule-based but others may use machine learning techniques.
  • In some implementations, for each message type, as disambiguated, the online service follows a process of responding to and handling the message type as if the request in the message had been submitted/taken as an action on a web site of the online service.
  • In some implementations, the online service allows its users to communicate with the online service and convey requests using natural language and a predefined structure for processing the communications. The structure has, for example, one or more rules for processing communications from users and determining how to proceed. For example, a rule may be that a reply with a specific term conveys a specific type of request. Another rule may be that certain terms are known to be ambiguous, and thus trigger follow-ups for clarification (e.g., follow-up communication soliciting clarification or even human intervention). In the allowance of user communication using natural language and the user of a defined language structure to process the communications, the online service may be considered to be a conversational interface. In general, conversational interfaces are like language oriented state machines, where the states may require very specific structure, or very broad interpretation (e.g., replying “buy” to a tweet kicks off a state flow that results in a purchase). Further, the state flow through the state machine of the conversational interface can be linear or interleaving; just as one can explore a website linearly (e.g., by referencing a sitemap) or in a path-dependent manner where the next page to visit is based on what is in the current page, communications in a conversational interface can have similar properties—a linear flow or an interleaving flow.
  • In some implementations, multiple channels or modes of communication (e.g., email, social networks, instant messaging, telephony, etc.) are available for communications between users and the online service. Within a conversation thread between the user and the online service, the user can switch modes. For example, the user starts out sending email to the online service, and then switches to instant messaging. The online service detects the change and switches to match the communication channel used by the user.
  • In some implementations, internal services within the online service communicate with a single interface by specifying a target user combined with a payload of metadata pertaining to the outbound message. The interface receiving this information identifies a set of possible channels for the target user by calling a set of classification services. Once a channel has been identified, it is stored and used for all further communication.
  • FIG. 1 is a block diagram illustrating a client-server environment 100 in accordance with some implementations. The client-server environment 100 includes one or more client systems 102-1 and 102-2, a server system 120, and one or more vendors 160, all connected over a network 110. In some implementations, the client system 102 includes one or more client applications 104 and a display 106. The server system 120 includes a user communication module 128, an information gathering module 124, a request processing module 126, and a user profile database 130. The network 110 may consist of any one or more of any of a variety of networks, including local area networks (LAN), wide area networks (WAN), wireless networks, wired networks, the Internet, or any combination of such networks.
  • In accordance with some implementations, the client system 102 includes one or more client applications 104. The one or more client applications 104 include, but are not limited to, a web browsing application for connecting to the server system 120. The client system 102 also includes a display 106. In some implementations, the client system is a computing device with the display integrated directly the device itself, such as a laptop, a smart phone, and a tablet computer. In other implementations the display is connected to, but not integrated into the client system. For example, desktop computer systems often do not have an integrated display and instead connect to a standalone display.
  • In some implementations, the client system 102 sends communications to and receives communications form the server system 120 over any viable communication medium. For example, a communication can be transmitted via e-mail, text, voice mail, social media message, an instant message, a message through a messaging service internal to the server system, or through the messaging service of another web service or web site.
  • In some implementations, when the user of the client system 102 replies to a communication from the server system 120, the client system 102 sends the response to the server system 120 via the same communication method that was used to send the replied-to communication. For example, if the original communication was received through an email message, the client system then uses the email messaging system to send a response. In some implementations, the client system 102 uses a different communication method to send a response. For example, the original communication is sent as an instant message through a chat program. Instead of responding through the chat program, the user sends a response via an email.
  • In accordance with some implementations, the server system 120 includes a user communication module 128, an information gathering module 124, a request processing module 126, and a user profile database 130. The user communication module 128 is configured to send and receive communications with a user, through any communication channel the user selects. The user communications module 128 also determines the user's selected communication channel if the user leaves the previous communication channel, receives requests from users, and receives indication from a user that they are changing their current communication channel.
  • In some implementations, the user communication module 128 determines the communication method based on past communications with the user of the client system. Thus, the user communication module 128 chooses the communication method that the user of the client system 102 uses most often when communicating with the server system. For example, if a user communicates with the server system 120 through email in 75% of communications, the server system 120 will use an email messaging system to communicate with the user. In some implementations, each user selects a preferred communication method and this preference is stored in the user profile database 130. For example, a user selects text messaging as the preferred method for receiving messages and in response the user communication module 128 will then use text messages to send communications to the user, unless directed otherwise. In some implementations, the user communication module 128 will use multiple communication methods to send communications to the user.
  • In some implementations, the user communication module 128 chooses the communication method based on the time and date that the communication is to be sent. For example, the user communication module 128 uses email messages to deliver communications during the standard workday (9 am-5 pm Monday through Friday) and uses text messages to deliver communications on the weekend and evenings. In some implementations, no communications will be sent during typical sleeping hours. In some implementations, each user selects time and data preferences for the user communication module 128 to use and these preferences are stored in the user profile database 130.
  • In some implementations, the user communication module 128 receives responses from client systems 102. In some implementations, each response is transmitted to the request processing module 126. In some other implementations, each response is transmitted to the information gathering module 124 before it is transmitted to the request processing module 126. In yet other implementations, a copy of the response is transmitted to both to the information gathering module 124 and the request processing module 126.
  • In some implementations, the request processing module 126 receives a request from a user and determining whether the server system 120 can automatically respond to the request without human interaction, and if not, forward the request to a human operator for fulfillment. In some implementations, the request processing module 126 identifies the type of request, identifies the information needed to fulfill the request, and determines whether the server system 120 has the information needed to fulfill the request.
  • In some implementations, the information gathering module 124 gathers and collects data associated with users. The gathering and collecting of data include asking the user to provide or confirm data, crawling and extracting data from content hosts 160, and analyzing the user profile database 130 to infer additional data. In some implementations, asking of users to provide or confirm data is gradual (e.g., periodic) and/or responsive to user requests.
  • In some implementations the user profile database 130 contains user profiles for users who have registered to use the service provided by the server system 120. In some implementations, a user profile includes the name, ID, demographic information (gender, age, location, etc), purchasing history, social network information (including username and passwords for one or more social networking sites), and trust information. In some implementations, the user profile includes contact information submitted by the user or stored by the system after contact by the user including but not limited to email addresses, phone numbers, user names, instant message user IDs, and social networking sites user information sufficient to allow the service to access each of the user's social networking sites. In some implementations, the user communication module 128 uses information stored in the user profile database 130 to send communications to the client system 102.
  • In some implementations, the content hosts 160 host content external to the server system 120. Examples of content host(s) include web sites, social networks, and so on. In some implementations, the information gathering module 124 crawls the content host(s) 160 to gather information associated with users of the server system 120. The crawled information is presented to the respective users for confirmation, and information that is confirmed are stored in the user profile database 130.
  • FIG. 2 is a block diagram illustrating a client system 102, in accordance with some implementations. The client system 102 typically includes one or more processing units (CPUs) 202, one or more network interfaces 210, memory 212, and one or more communication buses 214 for interconnecting these components. The client system 102 includes a user interface 204. The user interface 204 includes an associated display device 106 and optionally includes an input means such as a keyboard, mouse, a touch sensitive display, or other input buttons 208. Optionally, the display device 106 includes an audio device or other information delivery device. Furthermore, some client systems use a microphone and voice recognition to supplement or replace the keyboard.
  • Memory 212 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 212 may optionally include one or more storage devices remotely located from the CPU(s) 202. Memory 212, or alternately the non-volatile memory device(s) within memory 212, includes a non-transitory computer readable storage medium. In some implementations, memory 212 or the computer readable storage medium of memory 212 stores the following programs, modules and data structures, or a subset thereof:
      • an operating system 216 that includes procedures for handling various basic system services and for performing hardware dependent tasks;
      • a network communication module 218 that is used for connecting the client system 102 to other computers via the one or more communication network interfaces 210 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on;
      • a display module 220 for enabling display of media content on a display 106 associated with the client system 102;
      • one or more client system 102 applications module(s) 104 for enabling the client system 102 to perform the functions offered by the client system 102, including but not limited to:
        • an application 224 for sending and receiving communications to/from a server system (FIG. 1, 120) and displaying the information (for example web pages) returned by the server system (FIG. 1, 120) or a smart phone or other computer system application that performs the same function; and
      • one or more client data module(s) 230 for storing data related to the client system 102, including but not limited to:
        • client message data 232, including data representing messages to be sent to the server system (FIG. 1, 120) and messages received from the server system (FIG. 1, 120); and
        • user profile data 234, including information concerning users of the client system 102 such as a user profile, user preferences and interests, user contact information, and other information relevant to providing services to the user.
  • FIG. 3 is a block diagram illustrating a server system 120, in accordance with some implementations. The server system 120 typically includes one or more processing units (CPUs) 302, one or more network interfaces 304, memory 306, and one or more communication buses 308 for interconnecting these components.
  • Memory 306 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 306 may optionally include one or more storage devices remotely located from the CPU(s) 302. Memory 306, or alternately the non-volatile memory device(s) within memory 306, includes a non-transitory computer readable storage medium. In some implementations, memory 306 or the computer readable storage medium of memory 306 stores the following programs, modules and data structures, or a subset thereof:
      • an operating system 310 that includes procedures for handling various basic system services and for performing hardware dependent tasks;
      • a network communication module 122 that is used for connecting the server system 120 to other computers via the one or more communication network interfaces 304 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on;
      • one or more server application module(s) 314 for enabling the server system 120 to perform the functions offered by the server system 120, including but not limited to:
        • an information gathering module 124 for gathering and collecting increasing amounts of data for a user, with the user's permission, while also conveying the purpose of the information gathering to the user;
        • a request processing module 126 for receiving a request from a user and determining whether the server system (FIG. 1, 120) can automatically respond to the request without human interaction, and if not, forward the request to a human operator for fulfillment;
        • a user communication module 128 for communicating with a user, through any communication channel the user selects, determining the users selected determination channel if the user leaves the previous communication channel; receiving requests from users, and receiving indication from a user that they are changing their current communication channel; and
      • one or more server data module(s) 330 for storing data related to the server system 120, including but not limited to:
        • user profile information database 130 including user preferences and interests, user contact information, and user history, including past user purchases, searches, page views, previous product recommendations, previous product reviews, social connections of the user, users' histories of previous requests, user relationship data, user trust data, user interest data, user payment data, the user's preferred communication channel; the user's current communication channel, and any other information related to the user.
  • FIG. 4 depicts a block diagram of an exemplary data structure for a user profile database 130 for storing information related to users of the server system (FIG. 1, 120). In accordance with some implementations, the user profile database 130 includes a plurality of user profiles 402-1 to 402-P, each of which corresponds to a user registered with the server system (FIG. 1, 120). In some implementations, each user profile 402 contains a user profile ID 404, a user history 406, trust information 408, recommendations 410 made by the user, and user contact information 412.
  • In some implementations, user profile ID 404 is a value that uniquely identifies a specific user of the server system (FIG. 1, 120). In some implementations, this value is chosen by the user and is a user name. In other implementations, this value is assigned to the user by the server system (FIG. 1, 120) as part of the registration process.
  • In some implementations, the user history 406 stores a history of the user's past interactions with the server system (FIG. 1, 120) including past user purchases, searches, page views, previous product recommendations, previous product reviews, and social connections of the user including previously recorded trust information for other users and/or social information received from social networking sites.
  • In some implementations, trust information 408 includes data describing the social connections of the user and includes a trust level for other users of the server system (FIG. 1, 120). A trust level is a value representing the degree to which a user trusts the opinions and recommendations of another user. In some implementations, trust information is explicitly submitted by the users, in other situations the server system (FIG. 1, 120) infers trust information from the actions of users, and in yet other situations trust information includes information from both user submissions and server inferences.
  • In some implementations, recommendation 410 data includes product purchases and product recommendations previously submitted by the user. In some implementations, contact information 412 includes a list of contact information for contacting the user through a plurality of communication methods and information describing if and when the server system (FIG. 1, 120) should use that method. For example, the contact information 412 includes an email address, a phone number, and a social network ID for the user. The user may select that the server system (FIG. 1, 120) should never use social network messaging to contact to user and should use email address at all times except for the weekend and that a text message to a mobile phone should be used on the weekend. In some implementations, the contact information 412 includes login and password information for one or more social networking sites.
  • FIG. 5 is a flow diagram illustrating the process for requesting user data in accordance with some implementations. Each of the operations shown in FIG. 5 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders). In some implementations, the method described in FIG. 5 is performed by the server system (FIG. 1, 120).
  • In some implementations, the server system (FIG. 1, 120) establishing a user profile (FIG. 4, 402) for a user (502). The user profile 402 includes one or more information items associated with the user (e.g., user history 406, contact information 412, etc.). In some implementations, the user profile is established when the user signs up for the online service that the server system 120 operates.
  • In some implementations, the server system (FIG. 1, 120) receives a request from the user to access additional services (504). For example, the server system 120 receives a communication from the user to recommend another user, recommend a good or service, or to purchase a good or service.
  • In some implementations, in response to receiving the user request, the server system (FIG. 1, 120) requesting additional information from the user (506). For example, if the request is a product recommendation, the server system 120 can ask the user to identify a user, within or without the online service that the server system 120 operates, that referred a product to the user making the request. In some implementations, requesting additional information from the user includes requesting information needed to fulfill the user request (508). For example, if the request is a request to purchase a good, the server system 120 sends communications to the user requesting that the user provide any information that is needed to make the purchase transaction but are not in the server system 120.
  • In some implementations, requesting additional information from the user includes requesting that the user confirm information associated with the user obtained from an information source. The server system 120 extracts information associated with the user that is obtained from a content host 160 (e.g., a third-party social network), and server system 120 asks the user to confirm the extracted information. For example, if the request is a product recommendation, the server system 120 can extract information about the product from content hosts 160 and asks the user to confirm the information. As another example, if the request is a purchase request, the server system 120 can look in the user profile database 130 for the user's past transactions, extract information from the past transactions that is relevant to the request, and ask the user to confirm that the extracted information is still valid. In some implementations, the information source is, for example, an online presence of the user, social network activity of the user, a communications history of the user, or a requests history of the user.
  • In some implementations, requesting additional information from the user includes requesting additional information from the user in accordance with a predefined information request sequence. The sequence can be defined, for example, by a state diagram, decision tree, or the like. With respect to a particular user profile 402, the location and path within the state diagram or decision tree is based on, for example, how much and what information is in the user profile, if the user is making a request, and the type of request, if any.
  • In some implementations, the server system 120 periodically makes unprompted requests for additional information from the user (508). For example, the server system 120 periodically presents a solicitation of information to the user. The solicitation is not prompted by a specific user request. In some implementations, the unprompted requests are dictated by the state diagram or decision tree described above based on what information is already in the user profile.
  • In some implementations, the server system 120 receives the requested additional information from the user (510), and adds the received additional information to the user profile of the user (512). In some implementations, the server system 120 infers information associated with the user based on the received information (514), and adds the inferred information to the user profile of the user (516).
  • FIG. 6 is a flow diagram illustrating the process for of responding to requests submitted through a conversational interface in accordance with some implementations. Each of the operations shown in FIG. 6 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders). In some implementations, the method described in FIG. 6 is performed by the server system (FIG. 1, 120).
  • In accordance with some implementations, the server system (FIG. 1, 120) receives a request from a user through a conversational interface (602). The server system determines, based on the request, whether the system is able to fulfill the request automatically (604). The server system 120 and a user of the client system 102 exchange communications, in which the user conveys a request (e.g., a purchase, a recommendation, etc.) and the server system 120 receives the communications and determines the type of request the user is conveying and whether fulfillment of the request can be performed automatically, without human intervention.
  • In some implementations, determining whether the system is able to fulfill the request automatically includes, in accordance with a determination that a type of the request is ambiguous based on contents of the request, determining that the system is not able to fulfill the request without human intervention. For example, if the communication conveying the request has ambiguity (e.g., ambiguity regarding the type of request, ambiguity regarding information needed to fulfill the request), the request is determined to require human intervention for fulfillment.
  • In some implementations, determining whether the system is able to fulfill the request automatically includes, in accordance with a determination that one or more information items needed to fulfill the request requires in-person confirmation by the user, determining that the system is not able to fulfill the request without human intervention. For example, if the information needed for fulfilling the request includes sensitive information that is not already in the user profile, the server system 120 determines that the request requires a human administrator to communicate to the user in person (e.g., by phone, by video conference) to obtain and/or confirm the sensitive information.
  • In accordance with a determination that the system is able to fulfill the request automatically, the server system 120 fulfills the user request with no human interaction (606). For example, if the request is unambiguous and the server system 120 has all of the information needed to fulfill the request, the server system 120 fulfills the request without forwarding the request to a human administrator for fulfillment.
  • In accordance with a determination that the system is not able to fulfill the request without human intervention, the server system 120 sends the request to a human operator for fulfillment (608).
  • FIG. 7 is a flow diagram illustrating the process for enabling communication with a user in accordance with some implementations. Each of the operations shown in FIG. 7 may correspond to instructions stored in a computer memory or computer readable storage medium. Optional operations are indicated by dashed lines (e.g., boxes with dashed-line borders). In some implementations, the method described in FIG. 7 is performed by the server system (FIG. 1, 120).
  • In accordance with some implementations, the server system (FIG. 1, 120), sends communication data to a user using a first communication channel (702). The server system 120 determines that the user has ceased using the first communication channel for receiving communications (704). The server system 120 identifies a second communication channel currently being used by the user (706). The server system 120 sends further communication data to the user using the identified second communication channel (708).
  • Thus, for example, the server system 120 sends a communication to the user at the client system 102 using, for example, instant messaging. The server system 120 then determines that the user has ceased using instant messaging. The server system 120 identifies another communication channel (e.g., email), and sends future communications to the user using that another communication channel.
  • In some implementations, the first or the second communication channel is any of: email, chat messaging, text messaging, social networking, a website, message boards, voice communication (e.g., telephony, voicemail, voice over Internet Protocol, etc.), and video conferencing.
  • In some implementations, determining that the user has ceased using the first communication channel for receiving communication includes receiving a communication from the user on a communication channel different from the first communication channel. In some implementations, identifying the second communication channel includes identifying the communication channel at which the communication was received as the second communication channel. For example, if the server system 120 sends a communication to the user using the first communication channel and the user replies back using a communication channel different from the first communication channel, the server system 120 determines that the user has ceased using the first communication channel and has switched to a different communication channel. That different communication channel is identified as the second communication channel.
  • In some implementations, determining that the user has ceased using the first communication channel receiving communication includes determining, in accordance with a schedule, that the user desires to receive communication at a communication channel different from the first communication channel. In some implementations, identifying the second communication channel includes identifying the second communication channel in accordance with the schedule. For example, the user profile for a user may have data specifying a schedule when particular communications channels are preferred. Alternatively, such a schedule may be predefined system-wide behavior for the server system 120. The user's preferred communication channel for receiving communication changes with the time of day in accordance with the schedule, and the second communication channel is determined in accordance with the schedule as well.
  • In some implementations, determining that the user has ceased using the first communication channel receiving communication includes detecting a log-out by the user from the first communication channel. For example, if the server system 120 and the user is communicating through a channel within the system (e.g., instant messaging in a web site operated by the server system 120) and the user logs out from the channel (e.g., the user logs out from the web site), the server system 120 determines that the user has cease using the channel within the system for communications and proceeds to switch to another channel (e.g., email).
  • The foregoing description, for purpose of explanation, has been described with reference to specific implementations. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The implementations were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various implementations with various modifications as are suited to the particular use contemplated.
  • It will also be understood that, although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the present implementations. The first contact and the second contact are both contacts, but they are not the same contact.
  • The terminology used in the description of the implementations herein is for the purpose of describing particular implementations only and is not intended to be limiting. As used in the description of the implementations and the appended claims, the singular forms “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
  • As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context. Similarly, the phrase “if it is determined” or “if (a stated condition or event) is detected” may be construed to mean “upon determining” or “in response to determining” or “upon detecting (the stated condition or event)” or “in response to detecting (the stated condition or event),” depending on the context.

Claims (15)

What is claimed is:
1. A method for enabling communication with a user, the method comprising
at a computer system having one or more processors, a camera, and memory storing one or more programs for execution by the one or more processors:
sending communication data to a user using a first communication channel;
determining that the user has ceased using the first communication channel for receiving communications;
identifying a second communication channel; and
sending further communication data to the user using the identified second communication channel.
2. The method of claim 1, wherein determining that the user has ceased using the first communication channel for receiving communication comprises: receiving a communication from the user on a communication channel different from the first communication channel.
3. The method of claim 2, wherein identifying the second communication channel comprises: identifying the communication channel at which the communication was received as the second communication channel.
4. The method of claim 1, wherein determining that the user has ceased using the first communication channel receiving communication comprises: determining, in accordance with a schedule, that the user desires to receive communication at a communication channel different from the first communication channel.
5. The method of claim 4, wherein identifying the second communication channel comprises: identifying the second communication channel in accordance with the schedule.
6. The method of claim 1, wherein determining that the user has ceased using the first communication channel receiving communication comprises: detecting a log-out by the user from the first communication channel.
7. The method of claim 1, wherein the first or the second communication channel is selected from the group consisting of: email, chat messaging, text messaging, social networking, a website, message boards, voice communication, and video conferencing.
8. A server system for requesting user data, comprising:
one or more processors; and
memory storing one or more programs to be executed by the one or more processors;
the one or more programs comprising instructions for:
sending communication data to a user using a first communication channel;
determining that the user has ceased using the first communication channel for receiving communications;
identifying a second communication channel; and
sending further communication data to the user using the identified second communication channel.
9. The system of claim 8, comprising instructions for: receiving a communication from the user on a communication channel different from the first communication channel.
10. The system of claim 9, comprising instructions for: identifying the communication channel at which the communication was received as the second communication channel.
11. The system of claim 8, comprising instructions for: determining, in accordance with a schedule, that the user desires to receive communication at a communication channel different from the first communication channel.
12. The system of claim 11, comprising instructions for: identifying the second communication channel in accordance with the schedule.
13. The system of claim 8, comprising instructions for: detecting a log-out by the user from the first communication channel.
14. The system of claim 8, wherein the first or the second communication channel is selected from the group consisting of: email, chat messaging, text messaging, social networking, a website, message boards, voice communication, and video conferencing.
15. A non-transitory computer readable storage medium storing one or more programs configured for execution by a server system, the one or more programs comprising instructions for:
sending communication data to a user using a first communication channel;
determining that the user has ceased using the first communication channel for receiving communications;
identifying a second communication channel; and
sending further communication data to the user using the identified second communication channel.
US13/986,608 2012-05-17 2013-05-16 Universal Communications Infrastructure Abandoned US20130311621A1 (en)

Priority Applications (6)

Application Number Priority Date Filing Date Title
US13/986,608 US20130311621A1 (en) 2012-05-17 2013-05-16 Universal Communications Infrastructure
PCT/US2013/041714 WO2013173799A1 (en) 2012-05-17 2013-05-17 Reward structures
PCT/US2013/041700 WO2013173788A1 (en) 2012-05-17 2013-05-17 Progressively asking for increasing amounts of user and network data
PCT/US2013/041702 WO2013173790A1 (en) 2012-05-17 2013-05-17 Trust graphs
PCT/US2013/041705 WO2013173792A1 (en) 2012-05-17 2013-05-17 Zero click commerce systems
US14/708,069 US10346895B2 (en) 2012-05-17 2015-05-08 Initiation of purchase transaction in response to a reply to a recommendation

Applications Claiming Priority (9)

Application Number Priority Date Filing Date Title
US201261648566P 2012-05-17 2012-05-17
US201261648582P 2012-05-17 2012-05-17
US201261648588P 2012-05-17 2012-05-17
US201261648569P 2012-05-17 2012-05-17
US201261648564P 2012-05-17 2012-05-17
US201261648578P 2012-05-17 2012-05-17
US201261648591P 2012-05-17 2012-05-17
US201261688655P 2012-05-18 2012-05-18
US13/986,608 US20130311621A1 (en) 2012-05-17 2013-05-16 Universal Communications Infrastructure

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US13/896,310 Continuation-In-Part US9799046B2 (en) 2012-05-17 2013-05-16 Zero click commerce systems

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US13/986,607 Continuation-In-Part US9875483B2 (en) 2012-05-17 2013-05-16 Conversational interfaces

Publications (1)

Publication Number Publication Date
US20130311621A1 true US20130311621A1 (en) 2013-11-21

Family

ID=49582070

Family Applications (7)

Application Number Title Priority Date Filing Date
US13/986,607 Active 2035-07-20 US9875483B2 (en) 2012-05-17 2013-05-16 Conversational interfaces
US13/986,606 Abandoned US20130311573A1 (en) 2012-05-17 2013-05-16 Progressively asking for increasing amounts of user and network data
US13/896,292 Active 2036-11-03 US10740779B2 (en) 2012-05-17 2013-05-16 Pre-establishing purchasing intent for computer based commerce systems
US13/986,608 Abandoned US20130311621A1 (en) 2012-05-17 2013-05-16 Universal Communications Infrastructure
US13/896,318 Abandoned US20130311260A1 (en) 2012-05-17 2013-05-16 Reward Structures
US13/986,612 Abandoned US20130311337A1 (en) 2012-05-17 2013-05-16 Universal consumption service
US13/896,310 Active 2035-09-23 US9799046B2 (en) 2012-05-17 2013-05-16 Zero click commerce systems

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US13/986,607 Active 2035-07-20 US9875483B2 (en) 2012-05-17 2013-05-16 Conversational interfaces
US13/986,606 Abandoned US20130311573A1 (en) 2012-05-17 2013-05-16 Progressively asking for increasing amounts of user and network data
US13/896,292 Active 2036-11-03 US10740779B2 (en) 2012-05-17 2013-05-16 Pre-establishing purchasing intent for computer based commerce systems

Family Applications After (3)

Application Number Title Priority Date Filing Date
US13/896,318 Abandoned US20130311260A1 (en) 2012-05-17 2013-05-16 Reward Structures
US13/986,612 Abandoned US20130311337A1 (en) 2012-05-17 2013-05-16 Universal consumption service
US13/896,310 Active 2035-09-23 US9799046B2 (en) 2012-05-17 2013-05-16 Zero click commerce systems

Country Status (1)

Country Link
US (7) US9875483B2 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140172996A1 (en) * 2012-12-14 2014-06-19 Facebook., Inc. Sending Notifications to Members of Social Group in a Social Networking System
US10042838B2 (en) * 2013-11-25 2018-08-07 Mov-Ology, Llc Obtaining data from incomplete electronic forms
US20180329754A1 (en) * 2017-05-10 2018-11-15 International Business Machines Corporation Non-directional transmissible task
US10929892B2 (en) 2017-10-05 2021-02-23 Mov-Ology, Llc Marketing to consumers using data obtained from abandoned GPS searches
EP3639506A4 (en) * 2017-06-13 2021-03-03 Uber Technologies, Inc. Customized communications for network systems
US20220393996A1 (en) * 2021-06-02 2022-12-08 Microsoft Technology Licensing, Llc System and method for converting an email thread to an instant message group

Families Citing this family (58)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8073681B2 (en) 2006-10-16 2011-12-06 Voicebox Technologies, Inc. System and method for a cooperative conversational voice user interface
GB0624577D0 (en) * 2006-12-08 2007-01-17 Skype Ltd Communication Systems
US7818176B2 (en) 2007-02-06 2010-10-19 Voicebox Technologies, Inc. System and method for selecting and presenting advertisements based on natural language processing of voice-based input
US8140335B2 (en) 2007-12-11 2012-03-20 Voicebox Technologies, Inc. System and method for providing a natural language voice user interface in an integrated voice navigation services environment
US9305548B2 (en) 2008-05-27 2016-04-05 Voicebox Technologies Corporation System and method for an integrated, multi-modal, multi-device natural language voice services environment
US8326637B2 (en) 2009-02-20 2012-12-04 Voicebox Technologies, Inc. System and method for processing multi-modal device interactions in a natural language voice services environment
US20110196726A1 (en) * 2009-08-10 2011-08-11 Devi Poellnitz System of Artist Referral and Media Selling, Promoting and Networking
US9760895B2 (en) 2012-06-04 2017-09-12 American Express Travel Related Services Company, Inc. Systems and methods for delivering tailored content based upon a consumer profile
US9355378B2 (en) 2013-03-14 2016-05-31 American Express Travel Related Services Company, Inc. Systems and methods for identifying and delivering tailored content based upon a service dialog
US9842142B2 (en) * 2013-03-15 2017-12-12 Ebay Inc. Self-guided verification of an item
US9094360B1 (en) * 2013-04-08 2015-07-28 Google Inc. Access right authorization
US9519928B2 (en) * 2013-07-29 2016-12-13 Bank Of American Corporation Product evaluation based on electronic receipt data
US9600839B2 (en) 2013-07-29 2017-03-21 Bank Of America Corporation Price evaluation based on electronic receipt data
US9324090B2 (en) * 2014-01-28 2016-04-26 Copernica, Inc. Method, system and apparatus for reinforcing desirable consumer behaviors with surprise rewards
WO2015145430A1 (en) 2014-03-23 2015-10-01 Melzer Roy S Instant messaging based financial transactions
US11080777B2 (en) 2014-03-31 2021-08-03 Monticello Enterprises LLC System and method for providing a social media shopping experience
US9626703B2 (en) 2014-09-16 2017-04-18 Voicebox Technologies Corporation Voice commerce
US9898459B2 (en) 2014-09-16 2018-02-20 Voicebox Technologies Corporation Integration of domain information into state transitions of a finite state transducer for natural language processing
US9917802B2 (en) * 2014-09-22 2018-03-13 Roy S. Melzer Interactive user interface based on analysis of chat messages content
EP3207467A4 (en) 2014-10-15 2018-05-23 VoiceBox Technologies Corporation System and method for providing follow-up responses to prior natural language inputs of a user
US20160110791A1 (en) * 2014-10-15 2016-04-21 Toshiba Global Commerce Solutions Holdings Corporation Method, computer program product, and system for providing a sensor-based environment
US10460351B2 (en) 2014-11-12 2019-10-29 International Business Machines Corporation Sales assistance based on purchasing prediction
US10614799B2 (en) 2014-11-26 2020-04-07 Voicebox Technologies Corporation System and method of providing intent predictions for an utterance prior to a system detection of an end of the utterance
US10431214B2 (en) 2014-11-26 2019-10-01 Voicebox Technologies Corporation System and method of determining a domain and/or an action related to a natural language input
US9443262B1 (en) * 2015-03-20 2016-09-13 Sears Brands, L.L.C. Merchandise reservation system, apparatus, and media
US10353542B2 (en) 2015-04-02 2019-07-16 Facebook, Inc. Techniques for context sensitive illustrated graphical user interface elements
US20160314513A1 (en) * 2015-04-24 2016-10-27 Ebay Inc. Automatic negotiation using real time messaging
US10270730B1 (en) * 2015-06-15 2019-04-23 Amazon Technologies, Inc. Determining a dynamic data feed
US10073794B2 (en) 2015-10-16 2018-09-11 Sprinklr, Inc. Mobile application builder program and its functionality for application development, providing the user an improved search capability for an expanded generic search based on the user's search criteria
US11004096B2 (en) 2015-11-25 2021-05-11 Sprinklr, Inc. Buy intent estimation and its applications for social media data
US20170153905A1 (en) * 2015-11-30 2017-06-01 Microsoft Technology Licensing, Llc User quest-anchored active digital memory assistant
US20170193592A1 (en) * 2016-01-05 2017-07-06 Rhino Saas IP Holding Co, LLC Method, system, and computer-readable storage medium for facilitating recurring ordering, billing, and inventory updating
US20170221021A1 (en) * 2016-01-29 2017-08-03 Rafael Gazetov Method and system for digital currency creation and marketing
US20170256177A1 (en) * 2016-03-01 2017-09-07 International Business Machines Corporation Genealogy and hereditary based analytics and delivery
MX2018012578A (en) 2016-04-15 2019-03-01 Walmart Apollo Llc Systems and methods for providing content-based product recommendations.
MX2018012574A (en) 2016-04-15 2019-03-06 Walmart Apollo Llc Partiality vector refinement systems and methods through sample probing.
WO2017180977A1 (en) 2016-04-15 2017-10-19 Wal-Mart Stores, Inc. Systems and methods for facilitating shopping in a physical retail facility
US11010820B2 (en) * 2016-05-05 2021-05-18 Transform Sr Brands Llc Request fulfillment system, method, and media
US10373464B2 (en) 2016-07-07 2019-08-06 Walmart Apollo, Llc Apparatus and method for updating partiality vectors based on monitoring of person and his or her home
US10331784B2 (en) 2016-07-29 2019-06-25 Voicebox Technologies Corporation System and method of disambiguating natural language processing requests
US10397326B2 (en) 2017-01-11 2019-08-27 Sprinklr, Inc. IRC-Infoid data standardization for use in a plurality of mobile applications
US20180213009A1 (en) * 2017-01-24 2018-07-26 Essential Products, Inc. Media and communications in a connected environment
WO2018191451A1 (en) 2017-04-13 2018-10-18 Walmart Apollo, Llc Systems and methods for receiving retail products at a delivery destination
US10649417B2 (en) 2017-05-31 2020-05-12 Microsoft Technology Licensing, Llc Controlling tenant services based on tenant usage performance indicators
US10511692B2 (en) 2017-06-22 2019-12-17 Bank Of America Corporation Data transmission to a networked resource based on contextual information
US10313480B2 (en) 2017-06-22 2019-06-04 Bank Of America Corporation Data transmission between networked resources
US10524165B2 (en) 2017-06-22 2019-12-31 Bank Of America Corporation Dynamic utilization of alternative resources based on token association
US10616357B2 (en) * 2017-08-24 2020-04-07 Bank Of America Corporation Event tracking and notification based on sensed data
CN109767279A (en) * 2017-11-10 2019-05-17 阿里巴巴集团控股有限公司 Order processing method, system and equipment
CN108764985A (en) * 2018-05-17 2018-11-06 上海炫栎网络科技有限公司 Beat reward method, apparatus and system
EP3850573A1 (en) * 2018-09-14 2021-07-21 Philippe Laik Interaction recommendation system
CN109741154B (en) * 2019-01-21 2021-03-19 长沙市力耀信息技术有限公司 Method for realizing social assistance payment and sharing shopping based on internet and shopping system
US10970732B2 (en) 2019-06-14 2021-04-06 MBP Insights, Inc. System and method for receiving real-time consumer transactional feedback
US11423491B1 (en) * 2019-08-01 2022-08-23 Block, Inc. Transacting via social media interactions
WO2021062021A1 (en) * 2019-09-25 2021-04-01 MBP Insights, Inc. Systems and methods for assessing merchant performance using real-time consumer transaction feedback
WO2021222439A1 (en) * 2020-04-28 2021-11-04 Rex Peter L Smart service routing using machine learning
US20220172304A1 (en) * 2020-12-02 2022-06-02 Tran Woods System and method for real time social engagement
WO2024013535A1 (en) * 2022-07-12 2024-01-18 Nielsen Consumer Llc Methods, systems, articles of manufacture and apparatus to facilitate participant connection

Citations (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5550576A (en) * 1995-04-17 1996-08-27 Starsight Telecast Incorporated Method and apparatus for merging television program schedule information received from multiple television schedule information sources
US5983004A (en) * 1991-09-20 1999-11-09 Shaw; Venson M. Computer, memory, telephone, communications, and transportation system and methods
US6185221B1 (en) * 1998-11-09 2001-02-06 Cabletron Systems, Inc. Method and apparatus for fair and efficient scheduling of variable-size data packets in an input-buffered multipoint switch
US20010016496A1 (en) * 2000-01-15 2001-08-23 Lee Sung-Won Apparatus and method for assigning a supplemental channel in mobile communication system
US6370381B1 (en) * 1999-01-29 2002-04-09 Siemens Transportation Systems, Inc. Multiple channel communications system
US20020078138A1 (en) * 2000-12-18 2002-06-20 Huang Paul C. Control system architecture for a multi-component armament system
US20020087704A1 (en) * 2000-11-30 2002-07-04 Pascal Chesnais Systems and methods for routing messages to communications devices over a communications network
US6487390B1 (en) * 1996-12-18 2002-11-26 Clubcom, Inc. System and method for interactive on-demand information
US20030054827A1 (en) * 2000-09-11 2003-03-20 Schmidl Timothy M. Wireless communication channel selection using passive interference avoidance techniques
US20030056216A1 (en) * 1998-01-05 2003-03-20 Theodore D. Wugofski System for managing favorite channels
US20030188252A1 (en) * 2002-03-27 2003-10-02 Se-Hyoung Kim Apparatus and method for receiving packet data control channel in a mobile communication system
US20030217291A1 (en) * 2002-03-18 2003-11-20 Merck & Company, Inc. Method and system for real-time secure transfer of personal information between websites
US20040117860A1 (en) * 2002-09-19 2004-06-17 Lg Electronics Inc. Multicast service providing method in mobile communication system
US20050216144A1 (en) * 2004-03-25 2005-09-29 Baldassa John A Vehicle website audio/video communication link
US7092381B2 (en) * 2000-12-29 2006-08-15 Telefonaktiebolaget Lm Ericsson (Publ) Delivery of broadcast teleservice messages over packet data networks
US20070143816A1 (en) * 2005-12-15 2007-06-21 Gupta Vikram M Methods for using broadcast media content information and related broadcast media receivers/playback devices
US20070199019A1 (en) * 2006-02-17 2007-08-23 Angiolillo Joel S Systems and methods for providing a personal channel via television
US20080271080A1 (en) * 2007-04-30 2008-10-30 Google Inc. Customizable Media Channels
US20090019484A1 (en) * 2007-07-12 2009-01-15 Lg Electronics Inc. Mobile terminal, and broadcast channel and broadcast information indictation method thereof
US20090106366A1 (en) * 2007-10-17 2009-04-23 Nokia Corporation System and method for visualizing threaded communication across multiple communication channels using a mobile web server
US20090175214A1 (en) * 2008-01-02 2009-07-09 Interdigital Technology Corporation Method and apparatus for cooperative wireless communications
US20090190544A1 (en) * 2008-01-25 2009-07-30 Qualcomm Incorporated Method and apparatus for channel identification in a wireless communication system
US20090222873A1 (en) * 2005-03-07 2009-09-03 Einarsson Torbjoern Multimedia Channel Switching
US20100279618A1 (en) * 2009-04-30 2010-11-04 Morton John Maclean Approach For Selecting Communications Channels In Communication Systems To Avoid Interference
US20110255448A1 (en) * 2010-04-15 2011-10-20 General Electric Company Generalized division free duplexing techniques for decreasing rendevous time
US20120117584A1 (en) * 2010-11-01 2012-05-10 Gordon Donald F Method and System for Presenting Additional Content at a Media System
US8181232B2 (en) * 2005-07-29 2012-05-15 Citicorp Development Center, Inc. Methods and systems for secure user authentication
US20120163309A1 (en) * 2010-10-11 2012-06-28 Interdigital Patent Holdings, Inc. Method and apparatus for bandwidth allocation for cognitive radio networks
US20120170534A1 (en) * 2010-01-26 2012-07-05 Eunsun Kim Station Operation Method and Apparatus in TV Whitespace
US20130094537A1 (en) * 2011-10-13 2013-04-18 Cisco Technology, Inc. Dynamic hopping sequence computation in channel hopping communication networks
US20130178239A1 (en) * 2012-01-09 2013-07-11 Robin U. Roberts System and method to facilitate time management for protected areas
US20130219468A1 (en) * 2012-02-16 2013-08-22 Citrix Systems, Inc. Connection Leasing for Hosted Services
US20130291007A1 (en) * 2012-04-27 2013-10-31 United Video Properties, Inc. Systems and methods for indicating media asset access conflicts using a time bar
US9184898B2 (en) * 2005-08-01 2015-11-10 Google Technology Holdings LLC Channel quality indicator for time, frequency and spatial channel in terrestrial radio access network

Family Cites Families (122)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6912588B1 (en) 1998-04-02 2005-06-28 Intel Corporation System and method for managing client requests in client-server networks
US7302429B1 (en) 1999-04-11 2007-11-27 William Paul Wanker Customizable electronic commerce comparison system and method
US20120197722A1 (en) * 2006-08-14 2012-08-02 Ewinwin, Inc. Group buying search
US7505941B2 (en) * 1999-08-31 2009-03-17 American Express Travel Related Services Company, Inc. Methods and apparatus for conducting electronic transactions using biometrics
AU4308801A (en) 1999-12-06 2001-06-12 Webusiness Usa, Inc. E-commerce catalog construction by incorporation
KR20010076971A (en) 2000-01-29 2001-08-17 박규헌 Electronic commerce system having a intelligence shopping basket
US20010011235A1 (en) 2000-01-29 2001-08-02 E-Net Co., Ltd. Apparatus for realizing personal shops in an electronic commerce business
GB0004993D0 (en) 2000-03-01 2000-04-19 Moores Toby Interaction protocol
US7991680B2 (en) 2000-03-06 2011-08-02 Wellogix Technology Licensing, Llc Method and process for providing relevant data, comparing proposal alternatives, and reconciling proposals, invoices, and purchase orders with actual costs in a workflow process
US6521152B1 (en) 2000-03-16 2003-02-18 Honeywell International Inc. Method for forming fiber reinforced composite parts
US20020052752A1 (en) * 2000-10-30 2002-05-02 Mark Landesmann Serious intent mechanism and method
US8677423B2 (en) 2000-12-28 2014-03-18 At&T Intellectual Property I, L. P. Digital residential entertainment system
WO2002061658A2 (en) 2001-01-30 2002-08-08 Personal Genie, Inc. System and method for matching consumers with products
US20020120581A1 (en) 2001-02-26 2002-08-29 Schiavone Vincent J. Reply based electronic mail transactions
US7330895B1 (en) * 2001-03-15 2008-02-12 Microsoft Corporation Representation, decision models, and user interface for encoding managing preferences, and performing automated decision making about the timing and modalities of interpersonal communications
KR20020090816A (en) 2001-05-29 2002-12-05 (주)데카커뮤니케이션즈 The system and method of analyzing and managing the value of product to fit the customers' needs using the object-oriented theory
US7716704B2 (en) 2001-06-12 2010-05-11 Thomson Licensing Television program selection apparatus and method
US20030046173A1 (en) 2001-08-30 2003-03-06 Benjier James A. Store delivery of products ordered over a computer network
US20030212617A1 (en) 2002-05-13 2003-11-13 Stone James S. Accounts payable process
US7444297B2 (en) 2002-06-13 2008-10-28 Aol Llc, A Delaware Limited Liability Company Method and medium for associating a wish list with buddy list screen name
US7346587B2 (en) 2002-12-06 2008-03-18 Aol Llc Intelligent method of order completion in an e-commerce environment based on availability of stored billing information
US20040117482A1 (en) 2002-12-17 2004-06-17 International Business Machines Corporation Method, system, and program product for customizing an application
US20050004837A1 (en) 2003-01-22 2005-01-06 Duane Sweeney System and method for compounded marketing
JP2004326634A (en) 2003-04-28 2004-11-18 Hitachi Ltd Recommended data selecting device using confidential relationship between users
CN1871439B (en) * 2003-09-22 2011-02-02 博施瑞克罗斯公司 Pressure vessel assembly for integrated pressurized fluid system
US7797196B1 (en) * 2003-10-20 2010-09-14 At&T Intellectual Property I, L.P. Method, system, and storage medium for providing automated purchasing and delivery services
US8612208B2 (en) 2004-04-07 2013-12-17 Oracle Otc Subsidiary Llc Ontology for use with a system, method, and computer readable medium for retrieving information and response to a query
US20060047598A1 (en) * 2004-08-31 2006-03-02 E-Procure Solutions Corporation System and method for web-based procurement
US8170897B1 (en) 2004-11-16 2012-05-01 Amazon Technologies, Inc. Automated validation of results of human performance of tasks
US20070043583A1 (en) 2005-03-11 2007-02-22 The Arizona Board Of Regents On Behalf Of Arizona State University Reward driven online system utilizing user-generated tags as a bridge to suggested links
US8318906B2 (en) * 2005-04-15 2012-11-27 The Regents Of The University Of California EMP2 antibodies and their therapeutic uses
US20060277591A1 (en) 2005-06-01 2006-12-07 Arnold William C System to establish trust between policy systems and users
US7904524B2 (en) 2006-03-06 2011-03-08 Aggregate Knowledge Client recommendation mechanism
US7831439B1 (en) 2006-03-08 2010-11-09 Amazon Technologies, Inc. System and method for converting gifts
JP4841979B2 (en) 2006-03-17 2011-12-21 富士通株式会社 Fee optimization method and fee optimization program
US7996270B2 (en) * 2006-03-30 2011-08-09 Ebay Inc. Community based network shopping
WO2007127812A2 (en) 2006-04-25 2007-11-08 Pagebites Inc. Method for information gathering and dissemination in a social network
KR100807264B1 (en) 2006-04-29 2008-02-28 강찬구 System for online contents marketplace and the operation method thereof
US9094257B2 (en) 2006-06-30 2015-07-28 Centurylink Intellectual Property Llc System and method for selecting a content delivery network
US8477614B2 (en) 2006-06-30 2013-07-02 Centurylink Intellectual Property Llc System and method for routing calls if potential call paths are impaired or congested
WO2008011065A2 (en) 2006-07-17 2008-01-24 Next Jump, Inc. Communication system and method for narrowcasting
GB2440562A (en) * 2006-08-03 2008-02-06 Sony Uk Ltd Apparatus and method of data organisation
US8407765B2 (en) 2006-08-22 2013-03-26 Centurylink Intellectual Property Llc System and method for restricting access to network performance information tables
US9318108B2 (en) 2010-01-18 2016-04-19 Apple Inc. Intelligent automated assistant
US8064342B2 (en) 2006-10-27 2011-11-22 Verizon Patent And Licensing Inc. Load balancing session initiation protocol (SIP) servers
WO2008099978A1 (en) 2007-02-14 2008-08-21 Won-Young Song Multiple network marketing on electronic commerce
JP5149892B2 (en) 2007-03-08 2013-02-20 株式会社 超 Gifting system and gifting method
US8095521B2 (en) 2007-03-30 2012-01-10 Amazon Technologies, Inc. Recommendation system with cluster-based filtering of recommendations
US20080300940A1 (en) 2007-05-31 2008-12-04 Gosakan Aravamudan Capturing Consumer Requirements
US9524502B2 (en) * 2007-06-20 2016-12-20 Qualcomm Incorporated Management of dynamic electronic coupons
US10069924B2 (en) * 2007-07-25 2018-09-04 Oath Inc. Application programming interfaces for communication systems
JP5108679B2 (en) 2007-10-22 2012-12-26 ヤフー株式会社 User recommendation system, user recommendation method, product information output system, product information output method and program
US8494978B2 (en) 2007-11-02 2013-07-23 Ebay Inc. Inferring user preferences from an internet based social interactive construct
US20090132365A1 (en) * 2007-11-15 2009-05-21 Microsoft Corporation Search, advertising and social networking applications and services
US20090171760A1 (en) 2007-12-31 2009-07-02 Nokia Corporation Systems and Methods for Facilitating Electronic Commerce
US20110131106A1 (en) 2009-12-02 2011-06-02 George Eberstadt Using social network and transaction information
US20090228339A1 (en) 2008-03-05 2009-09-10 David Wolf Method and system for revenue per reverse redirect
US8190494B2 (en) 2008-03-11 2012-05-29 International Business Machines Corporation Order processing analysis tool
US8224714B2 (en) 2008-05-01 2012-07-17 Microsoft Corporation Peer to peer network personal assistant
US20090319436A1 (en) 2008-06-18 2009-12-24 Delip Andra Method and system of opinion analysis and recommendations in social platform applications
US8066370B2 (en) * 2008-07-02 2011-11-29 Johnson & Johnson Vision Care, Inc. Tinted contact lenses with crescent patterns
WO2010017596A1 (en) 2008-08-15 2010-02-18 Posse Ip Pty Limited On-line advertising
US8412625B2 (en) 2008-08-25 2013-04-02 Bruno Pilo' & Associates, Llc System and methods for a multi-channel payment platform
US8001056B2 (en) * 2008-09-19 2011-08-16 Yahoo! Inc. Progressive capture of prospect information for user profiles
US20100088148A1 (en) * 2008-10-02 2010-04-08 Presswala Irfan System and methodology for recommending purchases for a shopping intent
WO2010099632A1 (en) 2009-03-03 2010-09-10 Google Inc. Method and system for providing advertising to users of social network
US8775529B2 (en) 2009-05-08 2014-07-08 Raytheon Company Bridging communications between communication services using different protocols
WO2011008888A2 (en) * 2009-07-14 2011-01-20 Womm, Llc Dba Superior Business Network Computerized systems and processes for promoting businesses
US20110022465A1 (en) * 2009-07-24 2011-01-27 Prasannakumar Jobigenahally Malleshaiah System and Method for Managing Online Experiences Based on User Sentiment Characteristics and Publisher Targeting Goals
US20110106674A1 (en) 2009-10-29 2011-05-05 Jeffrey William Perlman Optimizing Transaction Scenarios With Automated Decision Making
US9514466B2 (en) * 2009-11-16 2016-12-06 Yahoo! Inc. Collecting and presenting data including links from communications sent to or from a user
US8671029B2 (en) 2010-01-11 2014-03-11 Ebay Inc. Method, medium, and system for managing recommendations in an online marketplace
JP2011170471A (en) 2010-02-17 2011-09-01 Nippon Telegr & Teleph Corp <Ntt> Social graph generation method, social graph generation device and program
WO2011106897A1 (en) * 2010-03-05 2011-09-09 Chrapko Evan V Systems and methods for conducting more reliable assessments with connectivity statistics
US10074094B2 (en) 2010-03-09 2018-09-11 Excalibur Ip, Llc Generating a user profile based on self disclosed public status information
US9152969B2 (en) * 2010-04-07 2015-10-06 Rovi Technologies Corporation Recommendation ranking system with distrust
KR20110117475A (en) 2010-04-21 2011-10-27 중앙대학교 산학협력단 Apparatus and method for inferring trust and reputation in web-based social network
US9098808B1 (en) 2010-04-22 2015-08-04 Google Inc. Social search engine
WO2011140261A1 (en) 2010-05-04 2011-11-10 Schmitt Steven J Systems and methods for analyzing candidates and positions utilizing a recommendation engine
US8788583B2 (en) 2010-05-13 2014-07-22 International Business Machines Corporation Sharing form training result utilizing a social network
WO2011149961A2 (en) * 2010-05-24 2011-12-01 Intersect Ptp, Inc. Systems and methods for identifying intersections using content metadata
US8620935B2 (en) * 2011-06-24 2013-12-31 Yahoo! Inc. Personalizing an online service based on data collected for a user of a computing device
US20110320373A1 (en) 2010-06-25 2011-12-29 Microsoft Corporation Product conversations among social groups
US8224823B1 (en) 2010-06-30 2012-07-17 A9.Com, Inc. Browsing history restoration
WO2012000543A1 (en) * 2010-06-30 2012-01-05 Telefonaktiebolaget Lm Ericsson (Publ) Method for selectively distributing information in a computer or communication network, and physical entities therefor
US8204805B2 (en) * 2010-10-28 2012-06-19 Intuit Inc. Instant tax return preparation
US8635227B2 (en) 2010-07-31 2014-01-21 Viralheat, Inc. Discerning human intent based on user-generated metadata
KR20120026859A (en) 2010-09-10 2012-03-20 삼성전자주식회사 Method and system for providing social network service using mobile terminal
US20120095841A1 (en) 2010-10-15 2012-04-19 Douglas Luckerman Electronic Marketplace for Energy
US20120095862A1 (en) 2010-10-15 2012-04-19 Ness Computing, Inc. (a Delaware Corportaion) Computer system and method for analyzing data sets and generating personalized recommendations
US8799108B2 (en) 2010-11-03 2014-08-05 Verizon Patent And Licensing Inc. Passive shopping service optimization
US20120131441A1 (en) 2010-11-18 2012-05-24 Google Inc. Multi-Mode Web Browsing
CN102741875B (en) 2010-11-30 2017-10-17 松下电器(美国)知识产权公司 Content management device, contents management method, content supervisor and integrated circuit
WO2012083071A1 (en) * 2010-12-15 2012-06-21 Vineloop Social network information system and method
US9691055B2 (en) 2010-12-17 2017-06-27 Google Inc. Digital wallet
WO2012109002A1 (en) 2011-01-24 2012-08-16 Google Inc. Internet content quality evaluation
WO2012106626A2 (en) 2011-02-04 2012-08-09 Wts Paradigm System and method for evaluating computerized product customization tool and associate database(s)
US10204327B2 (en) 2011-02-05 2019-02-12 Visa International Service Association Merchant-consumer bridging platform apparatuses, methods and systems
US9870424B2 (en) * 2011-02-10 2018-01-16 Microsoft Technology Licensing, Llc Social network based contextual ranking
US20120209839A1 (en) * 2011-02-15 2012-08-16 Microsoft Corporation Providing applications with personalized and contextually relevant content
US8676742B2 (en) * 2011-03-29 2014-03-18 Manyworlds, Inc. Contextual scope-based discovery systems
US9858343B2 (en) * 2011-03-31 2018-01-02 Microsoft Technology Licensing Llc Personalization of queries, conversations, and searches
US20120278127A1 (en) 2011-04-28 2012-11-01 Rawllin International Inc. Generating product recommendations based on dynamic product context data and/or social activity data related to a product
US9369285B2 (en) 2011-04-28 2016-06-14 Qualcomm Incorporated Social network based PKI authentication
US20140108445A1 (en) * 2011-05-05 2014-04-17 Google Inc. System and Method for Personalizing Query Suggestions Based on User Interest Profile
US20120290374A1 (en) 2011-05-13 2012-11-15 Dell Products L.P. Social Marketplace Process and Architecture
US8626604B1 (en) 2011-05-19 2014-01-07 Google Inc. Aggregating product endorsement information
US8736612B1 (en) 2011-07-12 2014-05-27 Relationship Science LLC Altering weights of edges in a social graph
US20130054407A1 (en) 2011-08-30 2013-02-28 Google Inc. System and Method for Recommending Items to Users Based on Social Graph Information
US9928485B2 (en) * 2011-09-07 2018-03-27 Elwha Llc Computational systems and methods for regulating information flow during interactions
US10546306B2 (en) 2011-09-07 2020-01-28 Elwha Llc Computational systems and methods for regulating information flow during interactions
US8756500B2 (en) 2011-09-20 2014-06-17 Microsoft Corporation Dynamic content feed filtering
US20130091013A1 (en) * 2011-10-07 2013-04-11 Microsoft Corporation Presenting Targeted Social Advertisements
WO2013055818A1 (en) 2011-10-11 2013-04-18 Applyrapid, Inc. Online system, apparatus, and method for obtaining or applying for information, programs, services and/or products
US9009129B2 (en) 2011-10-12 2015-04-14 Microsoft Technology Licensing, Llc Presenting search results annotated with domain endorsements
US20130097056A1 (en) * 2011-10-13 2013-04-18 Xerox Corporation Methods and systems for recommending services based on an electronic social media trust model
US20130124357A1 (en) 2011-11-16 2013-05-16 Zhijiang He System and method for online buying and selling goods and services within the context of social networking
US20130332307A1 (en) * 2011-11-21 2013-12-12 Facebook, Inc. Method for notifying a sender of a gifting event
US20130191316A1 (en) 2011-12-07 2013-07-25 Netauthority, Inc. Using the software and hardware configurations of a networked computer to infer the user's demographic
US8463295B1 (en) * 2011-12-07 2013-06-11 Ebay Inc. Systems and methods for generating location-based group recommendations
US20130173334A1 (en) * 2011-12-07 2013-07-04 Uniloc Luxembourg S.A. Inferring user demographics through network activity records
US9547832B2 (en) 2012-01-10 2017-01-17 Oracle International Corporation Identifying individual intentions and determining responses to individual intentions

Patent Citations (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5983004A (en) * 1991-09-20 1999-11-09 Shaw; Venson M. Computer, memory, telephone, communications, and transportation system and methods
US5550576A (en) * 1995-04-17 1996-08-27 Starsight Telecast Incorporated Method and apparatus for merging television program schedule information received from multiple television schedule information sources
US6487390B1 (en) * 1996-12-18 2002-11-26 Clubcom, Inc. System and method for interactive on-demand information
US20030056216A1 (en) * 1998-01-05 2003-03-20 Theodore D. Wugofski System for managing favorite channels
US6185221B1 (en) * 1998-11-09 2001-02-06 Cabletron Systems, Inc. Method and apparatus for fair and efficient scheduling of variable-size data packets in an input-buffered multipoint switch
US6370381B1 (en) * 1999-01-29 2002-04-09 Siemens Transportation Systems, Inc. Multiple channel communications system
US20010016496A1 (en) * 2000-01-15 2001-08-23 Lee Sung-Won Apparatus and method for assigning a supplemental channel in mobile communication system
US20030054827A1 (en) * 2000-09-11 2003-03-20 Schmidl Timothy M. Wireless communication channel selection using passive interference avoidance techniques
US20020087704A1 (en) * 2000-11-30 2002-07-04 Pascal Chesnais Systems and methods for routing messages to communications devices over a communications network
US20020078138A1 (en) * 2000-12-18 2002-06-20 Huang Paul C. Control system architecture for a multi-component armament system
US7092381B2 (en) * 2000-12-29 2006-08-15 Telefonaktiebolaget Lm Ericsson (Publ) Delivery of broadcast teleservice messages over packet data networks
US20030217291A1 (en) * 2002-03-18 2003-11-20 Merck & Company, Inc. Method and system for real-time secure transfer of personal information between websites
US20030188252A1 (en) * 2002-03-27 2003-10-02 Se-Hyoung Kim Apparatus and method for receiving packet data control channel in a mobile communication system
US20040117860A1 (en) * 2002-09-19 2004-06-17 Lg Electronics Inc. Multicast service providing method in mobile communication system
US20050216144A1 (en) * 2004-03-25 2005-09-29 Baldassa John A Vehicle website audio/video communication link
US20090222873A1 (en) * 2005-03-07 2009-09-03 Einarsson Torbjoern Multimedia Channel Switching
US8181232B2 (en) * 2005-07-29 2012-05-15 Citicorp Development Center, Inc. Methods and systems for secure user authentication
US9184898B2 (en) * 2005-08-01 2015-11-10 Google Technology Holdings LLC Channel quality indicator for time, frequency and spatial channel in terrestrial radio access network
US20070143816A1 (en) * 2005-12-15 2007-06-21 Gupta Vikram M Methods for using broadcast media content information and related broadcast media receivers/playback devices
US20070199019A1 (en) * 2006-02-17 2007-08-23 Angiolillo Joel S Systems and methods for providing a personal channel via television
US20080271080A1 (en) * 2007-04-30 2008-10-30 Google Inc. Customizable Media Channels
US20090019484A1 (en) * 2007-07-12 2009-01-15 Lg Electronics Inc. Mobile terminal, and broadcast channel and broadcast information indictation method thereof
US20090106366A1 (en) * 2007-10-17 2009-04-23 Nokia Corporation System and method for visualizing threaded communication across multiple communication channels using a mobile web server
US20090175214A1 (en) * 2008-01-02 2009-07-09 Interdigital Technology Corporation Method and apparatus for cooperative wireless communications
US20090190544A1 (en) * 2008-01-25 2009-07-30 Qualcomm Incorporated Method and apparatus for channel identification in a wireless communication system
US20100279618A1 (en) * 2009-04-30 2010-11-04 Morton John Maclean Approach For Selecting Communications Channels In Communication Systems To Avoid Interference
US20120170534A1 (en) * 2010-01-26 2012-07-05 Eunsun Kim Station Operation Method and Apparatus in TV Whitespace
US20110255448A1 (en) * 2010-04-15 2011-10-20 General Electric Company Generalized division free duplexing techniques for decreasing rendevous time
US20120163309A1 (en) * 2010-10-11 2012-06-28 Interdigital Patent Holdings, Inc. Method and apparatus for bandwidth allocation for cognitive radio networks
US20120117584A1 (en) * 2010-11-01 2012-05-10 Gordon Donald F Method and System for Presenting Additional Content at a Media System
US20130094537A1 (en) * 2011-10-13 2013-04-18 Cisco Technology, Inc. Dynamic hopping sequence computation in channel hopping communication networks
US20130178239A1 (en) * 2012-01-09 2013-07-11 Robin U. Roberts System and method to facilitate time management for protected areas
US20130219468A1 (en) * 2012-02-16 2013-08-22 Citrix Systems, Inc. Connection Leasing for Hosted Services
US20130291007A1 (en) * 2012-04-27 2013-10-31 United Video Properties, Inc. Systems and methods for indicating media asset access conflicts using a time bar

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
Merriam-Webster, "cease", 2015 *
Merriam-Webster, "log on", 2016 *
Merriam-Webster, "log out", 2016 *
Merriam-Webster, "majority", 2015 *
Merriam-Webster, "primary", 2015 *
Merriam-Webster, "schedule", 2016 *

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10397162B2 (en) * 2012-12-14 2019-08-27 Facebook, Inc. Sending notifications to members of social group in a social networking system
US20140172996A1 (en) * 2012-12-14 2014-06-19 Facebook., Inc. Sending Notifications to Members of Social Group in a Social Networking System
US10042838B2 (en) * 2013-11-25 2018-08-07 Mov-Ology, Llc Obtaining data from incomplete electronic forms
US10769358B2 (en) 2013-11-25 2020-09-08 Mov-Ology, Llc Obtaining data from incomplete electronic forms
US10613904B2 (en) * 2017-05-10 2020-04-07 International Business Machines Corporation Non-directional transmissible task
US10606655B2 (en) * 2017-05-10 2020-03-31 International Business Machines Corporation Non-directional transmissible task
US20190065273A1 (en) * 2017-05-10 2019-02-28 International Business Machines Corporation Non-directional transmissible task
US20180329754A1 (en) * 2017-05-10 2018-11-15 International Business Machines Corporation Non-directional transmissible task
EP3639506A4 (en) * 2017-06-13 2021-03-03 Uber Technologies, Inc. Customized communications for network systems
US10929892B2 (en) 2017-10-05 2021-02-23 Mov-Ology, Llc Marketing to consumers using data obtained from abandoned GPS searches
US11410201B2 (en) 2017-10-05 2022-08-09 Mov-Ology, Llc Marketing to consumers using data obtained from abandoned GPS searches
US20220393996A1 (en) * 2021-06-02 2022-12-08 Microsoft Technology Licensing, Llc System and method for converting an email thread to an instant message group
US11677694B2 (en) * 2021-06-02 2023-06-13 Microsoft Technology Licensing, Llc System and method for converting an email thread to an instant message group

Also Published As

Publication number Publication date
US9875483B2 (en) 2018-01-23
US10740779B2 (en) 2020-08-11
US20130311323A1 (en) 2013-11-21
US9799046B2 (en) 2017-10-24
US20130311260A1 (en) 2013-11-21
US20130311573A1 (en) 2013-11-21
US20130311337A1 (en) 2013-11-21
US20130311324A1 (en) 2013-11-21
US20130311592A1 (en) 2013-11-21

Similar Documents

Publication Publication Date Title
US9875483B2 (en) Conversational interfaces
US11516264B2 (en) Methods and systems for soliciting an answer to a question
JP6726203B2 (en) Technology for authorizing and customizing social messaging
US20180176164A1 (en) Selective communication of messages
US9805127B2 (en) Methods and systems for utilizing activity data with clustered events
US20150199770A1 (en) Social And Commercial Internet Platform for Correlating, Crowdsourcing, and Convening People and Products of Related Characteristics Into A Virtual Social Network
US20230281668A1 (en) Tap to subscribe to text message alerts
US20130318180A1 (en) Leveraging a social graph to deliver relevant recommendations
US20150317398A1 (en) Presenting non-suggested content items to a user of a social network account
US9299099B1 (en) Providing recommendations in a social shopping trip
US9832162B2 (en) Viral invitations for social networks
WO2013173799A1 (en) Reward structures
US20170004515A1 (en) Techniques for providing a retail poll service
US20220269386A1 (en) Methods and Systems for Soliciting an Answer to a Question
US10560413B2 (en) Systems and methods associated with collective contact information
WO2013173788A1 (en) Progressively asking for increasing amounts of user and network data
US10438252B2 (en) Method and system for SMS intermediation
US8250139B2 (en) Demand-driven, collaborative systems and processes for collecting structured information
US20120284327A1 (en) Apparatus and methods for providing real time advice online
US8108463B2 (en) Demand-driven, collaborative systems and processes for collecting structured information
US20190190877A1 (en) Inverted fan-out for relevant notification of activity
US20190340621A1 (en) Connection fulfillment system
US11379890B2 (en) Conversational mapping of web items for mediated group decisions

Legal Events

Date Code Title Description
AS Assignment

Owner name: LUVOCRACY INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TYSON, JOSEPH;STOLL, NATHAN;REEL/FRAME:031065/0965

Effective date: 20130517

AS Assignment

Owner name: WAL-MART STORES, INC., ARKANSAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LUVOCRACY INC.;REEL/FRAME:035161/0350

Effective date: 20150312

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: WALMART APOLLO, LLC, ARKANSAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:WAL-MART STORES, INC.;REEL/FRAME:045817/0115

Effective date: 20180131