WO2013109494A1 - Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient - Google Patents

Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient Download PDF

Info

Publication number
WO2013109494A1
WO2013109494A1 PCT/US2013/021403 US2013021403W WO2013109494A1 WO 2013109494 A1 WO2013109494 A1 WO 2013109494A1 US 2013021403 W US2013021403 W US 2013021403W WO 2013109494 A1 WO2013109494 A1 WO 2013109494A1
Authority
WO
WIPO (PCT)
Prior art keywords
message
recipient
template
preferences
outgoing
Prior art date
Application number
PCT/US2013/021403
Other languages
French (fr)
Inventor
Kirill Buryak
Andrew Swerdlow
Luke Hiro SWARTZ
Cibu Chalissery JOHNY
Original Assignee
Google 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 Google Inc. filed Critical Google Inc.
Priority to EP13700839.7A priority Critical patent/EP2805442A4/en
Priority to KR1020147022595A priority patent/KR102050982B1/en
Priority to CN201380005644.3A priority patent/CN104170293B/en
Publication of WO2013109494A1 publication Critical patent/WO2013109494A1/en

Links

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
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • G06Q10/107Computer-aided management of electronic mailing [e-mailing]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • G06F40/186Templates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/40Processing or translation of natural language
    • G06F40/58Use of machine translation, e.g. for multi-lingual retrieval, for server-side translation for client devices or for real-time translation
    • 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
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • G06Q10/109Time management, e.g. calendars, reminders, meetings or time accounting
    • 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
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • G06Q10/109Time management, e.g. calendars, reminders, meetings or time accounting
    • G06Q10/1093Calendar-based scheduling for persons or groups
    • G06Q10/1095Meeting or appointment
    • 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/02User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail using automatic reactions or user delegation, e.g. automatic replies or chatbot-generated messages
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/21Monitoring or handling of messages
    • H04L51/214Monitoring or handling of messages using selective forwarding
    • 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

Definitions

  • the present disclosure relates to techniques for generating personalized outgoing messages to a recipient based on preferences of the recipient, including language, internationalization, and localization preferences of a user.
  • a calendar application may allow a sender to invite a plurality of recipients to an event.
  • the sender can designate a particular time, a particular place, and/or a particular event type, e.g., meeting or party.
  • the calendar application can generate an outgoing message inviting the recipients to the event.
  • the outgoing messages that are generated are generated according to the settings of the application or based on the sender's preferences or practices.
  • a computer- implemented technique for generating outgoing messages includes receiving, at a message server having one or more processors, a request to generate an outgoing message for a recipient.
  • the technique further includes retrieving, at the message server, one or more recipient preferences of the recipient from a recipient preferences database.
  • the one or more recipient preferences relate to customization of messages that are to be delivered to the recipient.
  • the technique further includes retrieving, at the message server, a message template from a plurality of message templates stored in a message template database based on the request and the one or more recipient preferences.
  • the technique also includes generating, at the message server, the outgoing message based on the retrieved message template and the one or more recipient preferences, and providing, from the message server, the outgoing message to the recipient.
  • a computer- implemented system for generating outgoing messages includes a recipient preferences database that stores recipient preferences of a plurality of message recipients.
  • the recipient preferences of each one of the plurality of message recipients relate to customization of messages that are for the one message recipient.
  • the technique further includes a message template database that stores a plurality of message templates.
  • the technique also includes a message generation module that is configured to receive a request to generate an outgoing message for a recipient. The request indicates the recipient and message data for generating the outgoing message.
  • the message generation module is further configured to retrieve one or more recipient preferences of the recipient from the recipient preferences database, and retrieve a message template from a message template database based on the request and the one or more recipient preferences.
  • the message generation module is further configured to generate the outgoing message based on the retrieved message template and the one or more recipient preferences, and provide the outgoing message to the recipient.
  • FIG. 1 is a drawing illustrating an environment for generating and providing personalized outgoing messages according to some embodiments of the present disclosure
  • FIG. 2 is a block diagram illustrating example components of a message server according to some embodiments of the present disclosure
  • FIG. 3 is a flow chart illustrating an exemplary technique for generating outgoing messages according to some embodiments of the present disclosure.
  • FIG. 4 is a flow chart illustrating an exemplary technique for selecting a message template.
  • a sender device 20 may be any computing device such as a laptop computer, desktop computer, a mobile telephone, a tablet computer, or gaming devices. Further, the applications may be executed at an application server, e.g., application server 30-A, 30-B, or, 30-N (herein referenced as application server 30). An application executed by the application server 30 can be accessed by a sender at the sender device 20 by, for example, a web-browser or a client application. It should be appreciated that the application server 30 can execute any type of application or cloud-based service, such as a calendar application, a social networking website, an accounting application, a notification application, or an eCard application.
  • the sender from the sender device 20, can request that an outgoing message be sent to one or more recipients.
  • a request to generate an outgoing message for one or more recipients can be provided to a message server 10 by an application.
  • the request to generate an outgoing message can be sent on behalf of the sender or on behalf of the application.
  • the request can include a message type identifier identifying a type of message to be sent, a list of recipients, and message data that is particular to the outgoing message.
  • a request to generate a calendar invite may include a message type identifier indicating that the outgoing message is a calendar invite, a list of invitees that are to receive the invite, and message data particular to the invite such as a date, a time, a place, and an event type.
  • the message server 10 can generate an outgoing message.
  • the message server 10 may store a plurality of message templates corresponding to one or more applications.
  • a message template is a data structure that can be utilized to generate outgoing messages.
  • a message template may include one or more template placeholders and a text portion.
  • the message server 10 can generate an outgoing message by substituting message data received in the request in place of the template placeholders.
  • a message template for a calendar application may be " ⁇ Hello, ⁇ RECIPIENTJMAME ⁇ , ⁇ SENDERJMAME ⁇ has invited you to a ⁇ EVENT JYPE ⁇ at ⁇ LOCATION ⁇ on ⁇ DATE ⁇ at ⁇ TIME ⁇ .”
  • the template placeholders are ⁇ RECIPIENTJMAME ⁇ , ⁇ SENDERJMAME ⁇ , ⁇ EVENT JYPE ⁇ , ⁇ LOCATION ⁇ , ⁇ DATE ⁇ , and ⁇ TIME ⁇ .
  • the message server 10 can generate the outgoing message by substituting message data provided in the request for the template placeholders of the retrieved message template. For example, the message server 10 can insert a name of the recipient, a name of the sender, a type of event, a place of the event, the date of the event, and/or the time of the event into the message template.
  • the message server 10 can be configured to determine recipient preferences for each of the recipients.
  • the message server 10 can use the recipient preferences to generate the outgoing message.
  • the recipient preferences may designate a list of languages understood by the recipient (including a primary language of the recipient), a preferred date format of the recipient, a preferred currency of the recipient, and/or preferred measurement units of the recipient.
  • Other recipient preferences may also include calendar preferences of the recipient, number formatting preferences of the recipient, time formatting preferences of the recipient, a time-zone preference of the recipient, and a language dialect preference of the recipient.
  • the message server 10 can retrieve a message template having a text portion that is in the primary language of the recipient, and/or format the message data in accordance with the recipient preferences, e.g., a monetary amount can be displayed in the recipient's currency and a date can be displayed in the recipient's preferred date format.
  • the outgoing message can be transmitted to a recipient device 40. Similar to the sender device 20, the recipient device 40 may be any personal computing device. Further, it should be appreciated that the outgoing message can be provided to the recipient device 40 in any suitable manner. For instance, the outgoing message may be provided as an email message, a message service (SMS) message, a multimedia messaging service (MMS) message, a notification, or in any other suitable format.
  • SMS message service
  • MMS multimedia messaging service
  • the message server 10 may include a message generation module 210, a recipient preferences database 220, and a message template database 230. Further, the message server 10 may include or may be in communication with a translation engine 240.
  • the message generation module 210 can receive requests to generate an outgoing message from one or more application servers 30 and/or a sender device 20.
  • the request can include a message type identifier, a list of recipients, and message data.
  • the message data may include any values that are used to generate the outgoing message. In some situations, the message data may further include additional text provided by the sender that is to be inserted into the outgoing message.
  • the message generation module 210 can determine the intended recipients of the message based on the request. For each intended recipient, the message generation module 210 can retrieve recipient preferences from the recipient preferences database 220.
  • the recipient preferences database 220 stores recipient preferences for each of a plurality of recipients. It should be appreciated that a recipient can be any user, including the sender. Each recipient can provide one or more recipient preferences during a registration process or in a subsequent update. The recipient can provide recipient preferences, including the language list of the recipient, the primary language of the recipient, the currency preference of the recipient, the date format preference of the recipient, and the time format preference of the recipient. It is appreciated that some of the recipient preferences such as date format preferences or currency preference can be determined from the country or region of the recipient as an alternative to being specifically provided by the recipient.
  • the recipient preferences can be stored as a part of or with a user profile of the recipient. It should be appreciated that the recipient preferences database 220 can be indexed or accessed using a name of the recipient, an email address of the recipient, an id number of the recipient, or any other suitable manner.
  • the message generation module 210 can further retrieve a message template to utilize for generating the outgoing message.
  • the message generation module 210 can retrieve the message template based on the request.
  • the request may indicate a message type identifier or any other mechanism for identifying which message template to use.
  • the message generation module 210 can retrieve a requested message template from the message template database 230 based on the message type identifier.
  • the message template database 230 may store a plurality of message templates corresponding to one or more applications. Furthermore, the message template database 230 may organize the plurality of message templates into one or more sets of message templates, wherein each set of message templates includes message templates of the same message type but in different languages. For example, the message template database 230 may store one or more sets of message templates that correspond to a calendar application, one or more sets of message templates that correspond to a social networking application, and one or more sets of message templates that correspond to an accounting application. Table I illustrates an example organization of the message template database 230 corresponding to the example provided above:
  • the message template database has two sets of message templates corresponding to the calendar application, a set of message templates corresponding to the social networking application, and a set of message templates corresponding to the accounting application.
  • a default message template may be in English, while each set of message templates has additional message templates in alternate languages.
  • the message template database 230 may store a message template corresponding to the message type identifier, e.g., the first set of calendar message templates may have a message type identifier of 1 -1 , while the second set of calendar message templates may have a message type identifier of 1 -2, and the language.
  • the sets of message templates corresponding to the calendar application are in English, French, Spanish, German, Chinese, and Korean.
  • the set of message templates corresponding to the social networking application are in English, German, Spanish, Dutch, Chinese, and Japanese.
  • the set of message templates corresponding to the accounting application are in English, French, and Spanish.
  • the message generation module 210 can retrieve a message template from the message template database 230 corresponding to the message type identifier and the recipient's primary language. If there are no message templates in the recipient's primary language, the message generation module 210 can select a message template in one of the other languages recited in the list of languages that are understood by the user. If there are no message templates corresponding to the message type identifier or in one of the languages that are understood by the recipient, then the message generation module 210 can retrieve a default message template in the default language, e.g., English.
  • the message generation module 210 can generate the outgoing message based on the message data received in the request, the recipient preferences retrieved from the recipient preferences database, and the retrieved message template.
  • the message template may include one or more template placeholders.
  • the message generation module 210 can replace the template placeholders with the message data received in the request.
  • the application requesting the outgoing message may be aware of the specific template placeholders used in the message templates corresponding to the application.
  • message data can include the specific values for each of the template placeholders for the message template identified by the message type identifier.
  • the message generation module 210 can substitute the values received in the message data into the message template to generate the outgoing message.
  • the message generation module 210 may generate the outgoing message in accordance with the recipient preferences. For instance, if the recipient preference of date format is in the European format, e.g., "day MONTH year," the message generation module 210 can format any dates listed in the outgoing message in accordance with the recipient preferences of the recipient. Similarly, if the message data in the request includes monetary values in dollars and the recipient preference of currency is in Euros, the message generation module 210 can convert a monetary value in the provided currency, e.g., Dollars, to the recipient's preferred currency, e.g., Euros, and can insert the converted monetary value into the output message. As should be appreciated, the message generation module 210 may be in communication with a server that converts currency values, measurement values, or any other values which may be require conversion.
  • a server that converts currency values, measurement values, or any other values which may be require conversion.
  • the message generation module 210 may be configured to format specific values in the outgoing message template in accordance with the recipient values.
  • the message generation module 210 may have templates for different date formats. For example, depending on the recipient preferences of the recipient, the date December 6, 201 1 may be formatted as "6 December 201 1 ,” “6 DEC 201 1 ,” “12/6/201 1 ,” “12.06.201 1 ,” or in any other format that is used.
  • the message generation module 210 can then substitute the values formatted in accordance with the recipient preferences in place of the template placeholders in the retrieved message template, thereby generating the outgoing message.
  • the message data received in the request may include additional text that is to be included in the outgoing message.
  • the sender may include a message to be included in the outgoing message such as "No gifts please.”
  • the message templates corresponding to the calendar invite may include a field for the additional text, but the text portion of the message templates may not have the actual additional text included therein. In these situations, once the message generation module 210 has retrieved the message template that will be used to generate the outgoing message, the message generation module 210 can provide the additional text to the translation engine 240.
  • the translation engine 240 translates the additional text from the language of the sender to the language of the retrieved message template and returns the translated text to the message generation module 210. For example, if the sender provided the additional text in English and the retrieved message template is in French, the message generation module 210 can have the translation engine 240 translate the additional text from English into French, and can insert the resultant translated text into the French message template to generate the outgoing message.
  • some template placeholders may be in place of words that would require translation.
  • the message data provided by the sender may require translation, e.g. common nouns, or transliteration, e.g., names or proper nouns.
  • the message generation module 210 may provide the message data that requires translation or transliteration to the translation engine 240, which returns the message data in the target language of the outgoing message.
  • the message generation module 210 can provide the outgoing message to the recipient. As was discussed above, the recipient can receive the outgoing message at the recipient device 40. The outgoing message can either be pushed to the recipient device 40 or the recipient device 40 may have to access the message server 10 or the application server 30 to obtain the outgoing message.
  • the message generation module 210 can receive a request to generate an outgoing message to one or more recipients.
  • the request may include a recipient indicator that indicates one or more intended recipients, a message type identifier, and message data.
  • the message generation module 210 can retrieve, for each of the intended recipients, the recipient preferences of the recipient from the recipient preferences database 220.
  • the recipient preferences of a particular recipient can relate to customization of messages that are to be delivered to the particular recipient.
  • the message generation module 210 can retrieve, for each recipient, a message template from the message template database 230 based on the message type identifier received in the request and the recipient preferences of the recipient. Namely, the message generation module 210 can retrieve the message template based on the list of languages understood by the recipient, including the primary language of the recipient. As will be described in greater detail below, the message generation module 210 can retrieve a message template that is in the primary language of the recipient, in another language understood by the recipient, or in a default language.
  • the message generation module 210 can generate outgoing messages based on the retrieved message templates.
  • the message templates may include template placeholders that represent values that can be represented in different formats or units.
  • the message generation module 210 determines recipient preferences regarding how each recipient prefers the values to be displayed, e.g., preferred date format or preferred currency.
  • the message generation module 210 can generate the values that are to replace the template placeholders in accordance with the recipient preferences.
  • the message generation module 210 can then substitute the values for the template placeholders, thereby generating the outgoing messages for each recipient.
  • the message generation module 210 can provide the outgoing messages to the one or more recipients.
  • the request may indicate more than one recipient. It should be appreciated that the foregoing technique 300 may be repeated for each recipient indicated in the request. Further, variations of the technique 300 are contemplated and are within the scope of this disclosure.
  • a request to generate an outgoing message can be provided to the message generation module 210, which retrieves the recipient preferences of the recipient based on the request.
  • the message generation module 210 can determine one or more languages of the recipient from the recipient preferences, including the primary language of the recipient.
  • the message generation module 210 can identify a set of message templates that correspond to the message type identifier included in the request.
  • the message template database 230 may include a plurality of message templates that correspond to one or more applications. Within the plurality of message templates, the message template database 230 stores one or more sets of message templates. Each set of message templates corresponds to a different message type and includes one or more message templates in one or more different languages. For example, a set of message templates corresponding to a social networking site may include different message templates in a plurality of different languages alerting the recipient that a user has added them to their network.
  • the set of message templates may include an English message template, e.g., " ⁇ PERSONJMAME ⁇ has added you to their network. ⁇ ,” and a Dutch message template, e.g., " ⁇ PERSONJMAME ⁇ heeft toegevoegd aan hun network. ⁇ .”
  • the example message templates would correspond to the same message type, and thus, can share the same message type identifier. Accordingly, the message generation module 210 can identify the set of message templates corresponding to the message type identifier received in the request.
  • the message generation module 210 can determine whether any of the message templates in the identified set of message templates is in the primary language of the recipient. If there is a message template in the set of message templates that is in the primary language of the recipient, that message template is retrieved from the message template database 230, as shown at 416. If there are no message templates in the set of message templates in the primary language of the recipient, the message generation module 210 can determine whether there are any message templates in the set of message templates that are in another language understood by the recipient, as shown at 418. If so, the message template in the other language is retrieved from the message template database 230, as shown at 420. If there are no message templates in a language that is understood by the recipient, a default message template can be retrieved from the message template database 230, as shown at 422.
  • the message generation module 210 can generate the outgoing message based on the retrieved message template and the recipient preferences. As described above, the message generation module 210 can format specific values received in the message data in accordance with the recipient preferences of the recipient.
  • Example embodiments are provided so that this disclosure will be thorough, and will fully convey the scope to those who are skilled in the art. Numerous specific details are set forth such as examples of specific components, devices, and methods, to provide a thorough understanding of embodiments of the present disclosure. It will be apparent to those skilled in the art that specific details need not be employed, that example embodiments may be embodied in many different forms and that neither should be construed to limit the scope of the disclosure. In some example embodiments, well-known procedures, well-known device structures, and well-known technologies are not described in detail.
  • first, second, third, etc. may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections should not be limited by these terms. These terms may be only used to distinguish one element, component, region, layer or section from another region, layer or section. Terms such as “first,” “second,” and other numerical terms when used herein do not imply a sequence or order unless clearly indicated by the context. Thus, a first element, component, region, layer or section discussed below could be termed a second element, component, region, layer or section without departing from the teachings of the example embodiments.
  • module may refer to, be part of, or include: an Application Specific Integrated Circuit (ASIC); an electronic circuit; a combinational logic circuit; a field programmable gate array (FPGA); a processor or a distributed network of processors (shared, dedicated, or grouped) and storage in networked clusters or datacenters that executes code or a process; other suitable components that provide the described functionality; or a combination of some or all of the above, such as in a system-on-chip.
  • the term module may also include memory (shared, dedicated, or grouped) that stores code executed by the one or more processors.
  • code may include software, firmware, byte- code and/or microcode, and may refer to programs, routines, functions, classes, and/or objects.
  • shared means that some or all code from multiple modules may be executed using a single (shared) processor. In addition, some or all code from multiple modules may be stored by a single (shared) memory.
  • group means that some or all code from a single module may be executed using a group of processors. In addition, some or all code from a single module may be stored using a group of memories.
  • the techniques described herein may be implemented by one or more computer programs executed by one or more processors.
  • the computer programs include processor-executable instructions that are stored on a non- transitory tangible computer readable medium.
  • the computer programs may also include stored data.
  • Non-limiting examples of the non-transitory tangible computer readable medium are nonvolatile memory, magnetic storage, and optical storage.
  • Certain aspects of the described techniques include process steps and instructions described herein in the form of an algorithm. It should be noted that the described process steps and instructions could be embodied in software, firmware or hardware, and when embodied in software, could be downloaded to reside on and be operated from different platforms used by real time network operating systems.
  • the present disclosure also relates to an apparatus for performing the operations herein.
  • This apparatus may be specially constructed for the required purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored on a computer readable medium that can be accessed by the computer.
  • a computer program may be stored in a tangible computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus.
  • the computers referred to in the specification may include a single processor or may be architectures employing multiple processor designs for increased computing capability.

Abstract

According to various embodiments of the disclosure techniques for generating outgoing messages are disclosed. The technique includes receiving a request to generate an outgoing message for a recipient and retrieving one or more recipient preferences of the recipient from a recipient preferences database. The one or more recipient preferences relate to customization of messages that are to be delivered to the recipient. The technique further includes retrieving a message template from a plurality of message templates stored in a message template database based on the request and the one or more recipient preferences. The technique also includes generating the outgoing message based on the retrieved message template and the one or more recipient preferences, and providing the outgoing message to the recipient.

Description

TECHNIQUES FOR GENERATING OUTGOING MESSAGES BASED ON LANGUAGE, INTERNATIONALIZATION, AND LOCALIZATION
PREFERENCES OF THE RECIPIENT
CROSS-REFERENCE TO RELATED APPLICATIONS
[0001] This application claims priority to United States Utility Application No. 13/351 ,031 , filed on January 16, 2012, the content of which is incorporated herein by reference in its entirety.
FIELD
[0002] The present disclosure relates to techniques for generating personalized outgoing messages to a recipient based on preferences of the recipient, including language, internationalization, and localization preferences of a user.
BACKGROUND
[0003] The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
[0004] Many computer applications allow users to generate messages to send to one or more recipients. Many of these applications utilize message templates to generate the messages that are sent to the recipients. For example, a calendar application may allow a sender to invite a plurality of recipients to an event. The sender can designate a particular time, a particular place, and/or a particular event type, e.g., meeting or party. Based on this information and a message template corresponding to an "event invite," the calendar application can generate an outgoing message inviting the recipients to the event. The outgoing messages that are generated, however, are generated according to the settings of the application or based on the sender's preferences or practices.
SUMMARY
[0005] According to various embodiments of the disclosure, a computer- implemented technique for generating outgoing messages is disclosed. The technique includes receiving, at a message server having one or more processors, a request to generate an outgoing message for a recipient. The technique further includes retrieving, at the message server, one or more recipient preferences of the recipient from a recipient preferences database. The one or more recipient preferences relate to customization of messages that are to be delivered to the recipient. The technique further includes retrieving, at the message server, a message template from a plurality of message templates stored in a message template database based on the request and the one or more recipient preferences. The technique also includes generating, at the message server, the outgoing message based on the retrieved message template and the one or more recipient preferences, and providing, from the message server, the outgoing message to the recipient.
[0006] According to various embodiments of the disclosure, a computer- implemented system for generating outgoing messages is disclosed. The technique includes a recipient preferences database that stores recipient preferences of a plurality of message recipients. The recipient preferences of each one of the plurality of message recipients relate to customization of messages that are for the one message recipient. The technique further includes a message template database that stores a plurality of message templates. The technique also includes a message generation module that is configured to receive a request to generate an outgoing message for a recipient. The request indicates the recipient and message data for generating the outgoing message. The message generation module is further configured to retrieve one or more recipient preferences of the recipient from the recipient preferences database, and retrieve a message template from a message template database based on the request and the one or more recipient preferences. The message generation module is further configured to generate the outgoing message based on the retrieved message template and the one or more recipient preferences, and provide the outgoing message to the recipient.
[0007] Further areas of applicability of the present disclosure will become apparent from the detailed description provided hereinafter. It should be understood that the detailed description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the disclosure.
BRIEF DESCRIPTION OF THE DRAWINGS
[0008] The present disclosure will become more fully understood from the detailed description and the accompanying drawings, wherein:
[0009] FIG. 1 is a drawing illustrating an environment for generating and providing personalized outgoing messages according to some embodiments of the present disclosure;
[0010] FIG. 2 is a block diagram illustrating example components of a message server according to some embodiments of the present disclosure;
[0011] FIG. 3 is a flow chart illustrating an exemplary technique for generating outgoing messages according to some embodiments of the present disclosure; and
[0012] FIG. 4 is a flow chart illustrating an exemplary technique for selecting a message template.
DETAILED DESCRIPTION
[0013] Referring to FIG. 1 , an example environment for generating and providing personalized outgoing messages is illustrated. Many applications allow senders to send messages to one or more recipients. These applications may be executed at a sender device 20. As should be appreciated, a sender device 20 may be any computing device such as a laptop computer, desktop computer, a mobile telephone, a tablet computer, or gaming devices. Further, the applications may be executed at an application server, e.g., application server 30-A, 30-B, or, 30-N (herein referenced as application server 30). An application executed by the application server 30 can be accessed by a sender at the sender device 20 by, for example, a web-browser or a client application. It should be appreciated that the application server 30 can execute any type of application or cloud-based service, such as a calendar application, a social networking website, an accounting application, a notification application, or an eCard application.
[0014] The sender, from the sender device 20, can request that an outgoing message be sent to one or more recipients. In some embodiments, a request to generate an outgoing message for one or more recipients can be provided to a message server 10 by an application. The request to generate an outgoing message can be sent on behalf of the sender or on behalf of the application. The request can include a message type identifier identifying a type of message to be sent, a list of recipients, and message data that is particular to the outgoing message. For example, a request to generate a calendar invite may include a message type identifier indicating that the outgoing message is a calendar invite, a list of invitees that are to receive the invite, and message data particular to the invite such as a date, a time, a place, and an event type. Based on the request, the message server 10 can generate an outgoing message.
[0015] The message server 10 may store a plurality of message templates corresponding to one or more applications. A message template is a data structure that can be utilized to generate outgoing messages. A message template may include one or more template placeholders and a text portion. The message server 10 can generate an outgoing message by substituting message data received in the request in place of the template placeholders.
[0016] For example, a message template for a calendar application may be "{Hello, {RECIPIENTJMAME}, {SENDERJMAME} has invited you to a {EVENT JYPE} at {LOCATION} on {DATE} at {TIME}." In this example, the template placeholders are {RECIPIENTJMAME}, {SENDERJMAME}, {EVENT JYPE}, {LOCATION}, {DATE}, and {TIME}. When the message server 10 receives a request to generate an outgoing message, the message server 10 can retrieve a message template of a message type which corresponds to the message type identifier in the request. The message server 10 can generate the outgoing message by substituting message data provided in the request for the template placeholders of the retrieved message template. For example, the message server 10 can insert a name of the recipient, a name of the sender, a type of event, a place of the event, the date of the event, and/or the time of the event into the message template.
[0017] The message server 10 can be configured to determine recipient preferences for each of the recipients. The message server 10 can use the recipient preferences to generate the outgoing message. For example, the recipient preferences may designate a list of languages understood by the recipient (including a primary language of the recipient), a preferred date format of the recipient, a preferred currency of the recipient, and/or preferred measurement units of the recipient. Other recipient preferences may also include calendar preferences of the recipient, number formatting preferences of the recipient, time formatting preferences of the recipient, a time-zone preference of the recipient, and a language dialect preference of the recipient. Based on the recipient preferences, the message server 10 can retrieve a message template having a text portion that is in the primary language of the recipient, and/or format the message data in accordance with the recipient preferences, e.g., a monetary amount can be displayed in the recipient's currency and a date can be displayed in the recipient's preferred date format.
[0018] Once an outgoing message is generated according to the recipient preferences, the outgoing message can be transmitted to a recipient device 40. Similar to the sender device 20, the recipient device 40 may be any personal computing device. Further, it should be appreciated that the outgoing message can be provided to the recipient device 40 in any suitable manner. For instance, the outgoing message may be provided as an email message, a message service (SMS) message, a multimedia messaging service (MMS) message, a notification, or in any other suitable format.
[0019] Referring now to FIG. 2, an example message server 10 is illustrated. The message server 10 may include a message generation module 210, a recipient preferences database 220, and a message template database 230. Further, the message server 10 may include or may be in communication with a translation engine 240.
[0020] The message generation module 210 can receive requests to generate an outgoing message from one or more application servers 30 and/or a sender device 20. As discussed above, the request can include a message type identifier, a list of recipients, and message data. As mentioned, the message data may include any values that are used to generate the outgoing message. In some situations, the message data may further include additional text provided by the sender that is to be inserted into the outgoing message.
[0021] The message generation module 210 can determine the intended recipients of the message based on the request. For each intended recipient, the message generation module 210 can retrieve recipient preferences from the recipient preferences database 220. The recipient preferences database 220 stores recipient preferences for each of a plurality of recipients. It should be appreciated that a recipient can be any user, including the sender. Each recipient can provide one or more recipient preferences during a registration process or in a subsequent update. The recipient can provide recipient preferences, including the language list of the recipient, the primary language of the recipient, the currency preference of the recipient, the date format preference of the recipient, and the time format preference of the recipient. It is appreciated that some of the recipient preferences such as date format preferences or currency preference can be determined from the country or region of the recipient as an alternative to being specifically provided by the recipient. In some embodiments, the recipient preferences can be stored as a part of or with a user profile of the recipient. It should be appreciated that the recipient preferences database 220 can be indexed or accessed using a name of the recipient, an email address of the recipient, an id number of the recipient, or any other suitable manner.
[0022] The message generation module 210 can further retrieve a message template to utilize for generating the outgoing message. The message generation module 210 can retrieve the message template based on the request.
As mentioned, in some embodiments the request may indicate a message type identifier or any other mechanism for identifying which message template to use.
The message generation module 210 can retrieve a requested message template from the message template database 230 based on the message type identifier.
[0023] The message template database 230 may store a plurality of message templates corresponding to one or more applications. Furthermore, the message template database 230 may organize the plurality of message templates into one or more sets of message templates, wherein each set of message templates includes message templates of the same message type but in different languages. For example, the message template database 230 may store one or more sets of message templates that correspond to a calendar application, one or more sets of message templates that correspond to a social networking application, and one or more sets of message templates that correspond to an accounting application. Table I illustrates an example organization of the message template database 230 corresponding to the example provided above:
Table I
Figure imgf000009_0001
[0024] In the example of Table I, the message template database has two sets of message templates corresponding to the calendar application, a set of message templates corresponding to the social networking application, and a set of message templates corresponding to the accounting application. A default message template may be in English, while each set of message templates has additional message templates in alternate languages. At each entry in the table, the message template database 230 may store a message template corresponding to the message type identifier, e.g., the first set of calendar message templates may have a message type identifier of 1 -1 , while the second set of calendar message templates may have a message type identifier of 1 -2, and the language. Thus, in the example, the sets of message templates corresponding to the calendar application are in English, French, Spanish, German, Chinese, and Korean. Similarly, the set of message templates corresponding to the social networking application are in English, German, Spanish, Dutch, Chinese, and Japanese. As should be further appreciated from the example, the set of message templates corresponding to the accounting application are in English, French, and Spanish. Thus, in this example, if a recipient is to receive a message corresponding to message type identifier 1 -1 and the recipient's primary language is French, the message generation module 210 can retrieve the message template corresponding to the message type identifier that is in French.
[0025] As should be appreciated from the foregoing, the message generation module 210 can retrieve a message template from the message template database 230 corresponding to the message type identifier and the recipient's primary language. If there are no message templates in the recipient's primary language, the message generation module 210 can select a message template in one of the other languages recited in the list of languages that are understood by the user. If there are no message templates corresponding to the message type identifier or in one of the languages that are understood by the recipient, then the message generation module 210 can retrieve a default message template in the default language, e.g., English.
[0026] Once the message generation module 210 has retrieved a message template, the message generation module 210 can generate the outgoing message based on the message data received in the request, the recipient preferences retrieved from the recipient preferences database, and the retrieved message template. As discussed above, the message template may include one or more template placeholders. The message generation module 210 can replace the template placeholders with the message data received in the request. As should be appreciated, the application requesting the outgoing message may be aware of the specific template placeholders used in the message templates corresponding to the application. Thus, message data can include the specific values for each of the template placeholders for the message template identified by the message type identifier. For example, if the message template is: "{Hello, {RECIPIENTJMAME}, {SENDERJMAME} has invited you to a {EVENT_TYPE} at {LOCATION} on {DATE} at {TIME}," the message data in the request may have values corresponding to the template placeholders: {RECIPIENT_NAME}, {SENDERJMAME}, {EVENT_TYPE}, {LOCATION}, {DATE}, and {TIME}. Thus, the message generation module 210 can substitute the values received in the message data into the message template to generate the outgoing message.
[0027] Further, the message generation module 210 may generate the outgoing message in accordance with the recipient preferences. For instance, if the recipient preference of date format is in the European format, e.g., "day MONTH year," the message generation module 210 can format any dates listed in the outgoing message in accordance with the recipient preferences of the recipient. Similarly, if the message data in the request includes monetary values in dollars and the recipient preference of currency is in Euros, the message generation module 210 can convert a monetary value in the provided currency, e.g., Dollars, to the recipient's preferred currency, e.g., Euros, and can insert the converted monetary value into the output message. As should be appreciated, the message generation module 210 may be in communication with a server that converts currency values, measurement values, or any other values which may be require conversion.
[0028] Additionally, the message generation module 210 may be configured to format specific values in the outgoing message template in accordance with the recipient values. In the example of a recipient preference for the date format, the message generation module 210 may have templates for different date formats. For example, depending on the recipient preferences of the recipient, the date December 6, 201 1 may be formatted as "6 December 201 1 ," "6 DEC 201 1 ," "12/6/201 1 ," "12.06.201 1 ," or in any other format that is used. The message generation module 210 can then substitute the values formatted in accordance with the recipient preferences in place of the template placeholders in the retrieved message template, thereby generating the outgoing message.
[0029] In some embodiments, the message data received in the request may include additional text that is to be included in the outgoing message. For example, in the example of a calendar invite to a party, the sender may include a message to be included in the outgoing message such as "No gifts please." As should be appreciated, the message templates corresponding to the calendar invite may include a field for the additional text, but the text portion of the message templates may not have the actual additional text included therein. In these situations, once the message generation module 210 has retrieved the message template that will be used to generate the outgoing message, the message generation module 210 can provide the additional text to the translation engine 240. The translation engine 240 translates the additional text from the language of the sender to the language of the retrieved message template and returns the translated text to the message generation module 210. For example, if the sender provided the additional text in English and the retrieved message template is in French, the message generation module 210 can have the translation engine 240 translate the additional text from English into French, and can insert the resultant translated text into the French message template to generate the outgoing message.
[0030] Similarly, some template placeholders may be in place of words that would require translation. For instance, if the template placeholder is for a location or an event type, the message data provided by the sender may require translation, e.g. common nouns, or transliteration, e.g., names or proper nouns. In these situations, the message generation module 210 may provide the message data that requires translation or transliteration to the translation engine 240, which returns the message data in the target language of the outgoing message.
[0031] The message generation module 210 can provide the outgoing message to the recipient. As was discussed above, the recipient can receive the outgoing message at the recipient device 40. The outgoing message can either be pushed to the recipient device 40 or the recipient device 40 may have to access the message server 10 or the application server 30 to obtain the outgoing message.
[0032] It should be appreciated that the techniques described above are provided for example only. Variations of the message server 10 are contemplated and are within the scope of this disclosure.
[0033] Referring now to FIG. 3, an example technique 300 for generating an outgoing message is illustrated. At 310, the message generation module 210 can receive a request to generate an outgoing message to one or more recipients. As discussed above, the request may include a recipient indicator that indicates one or more intended recipients, a message type identifier, and message data. At 312, the message generation module 210 can retrieve, for each of the intended recipients, the recipient preferences of the recipient from the recipient preferences database 220. As described previously, the recipient preferences of a particular recipient can relate to customization of messages that are to be delivered to the particular recipient.
[0034] At 314, the message generation module 210 can retrieve, for each recipient, a message template from the message template database 230 based on the message type identifier received in the request and the recipient preferences of the recipient. Namely, the message generation module 210 can retrieve the message template based on the list of languages understood by the recipient, including the primary language of the recipient. As will be described in greater detail below, the message generation module 210 can retrieve a message template that is in the primary language of the recipient, in another language understood by the recipient, or in a default language.
[0035] At 316, the message generation module 210 can generate outgoing messages based on the retrieved message templates. As discussed above, the message templates may include template placeholders that represent values that can be represented in different formats or units. The message generation module 210 determines recipient preferences regarding how each recipient prefers the values to be displayed, e.g., preferred date format or preferred currency. The message generation module 210 can generate the values that are to replace the template placeholders in accordance with the recipient preferences. The message generation module 210 can then substitute the values for the template placeholders, thereby generating the outgoing messages for each recipient. At 318, the message generation module 210 can provide the outgoing messages to the one or more recipients.
[0036] As discussed in greater detail above, the request may indicate more than one recipient. It should be appreciated that the foregoing technique 300 may be repeated for each recipient indicated in the request. Further, variations of the technique 300 are contemplated and are within the scope of this disclosure.
[0037] Referring now to FIG. 4, an example technique 400 for selecting a message template from a plurality of message templates is illustrated. As discussed above, a request to generate an outgoing message can be provided to the message generation module 210, which retrieves the recipient preferences of the recipient based on the request. At 410, the message generation module 210 can determine one or more languages of the recipient from the recipient preferences, including the primary language of the recipient.
[0038] At 412, the message generation module 210 can identify a set of message templates that correspond to the message type identifier included in the request. As discussed above, the message template database 230 may include a plurality of message templates that correspond to one or more applications. Within the plurality of message templates, the message template database 230 stores one or more sets of message templates. Each set of message templates corresponds to a different message type and includes one or more message templates in one or more different languages. For example, a set of message templates corresponding to a social networking site may include different message templates in a plurality of different languages alerting the recipient that a user has added them to their network. For example, the set of message templates may include an English message template, e.g., "{{PERSONJMAME} has added you to their network.}}," and a Dutch message template, e.g., "{{PERSONJMAME} heeft toegevoegd aan hun network.}}." It should be appreciated the example message templates would correspond to the same message type, and thus, can share the same message type identifier. Accordingly, the message generation module 210 can identify the set of message templates corresponding to the message type identifier received in the request.
[0039] At 414, the message generation module 210 can determine whether any of the message templates in the identified set of message templates is in the primary language of the recipient. If there is a message template in the set of message templates that is in the primary language of the recipient, that message template is retrieved from the message template database 230, as shown at 416. If there are no message templates in the set of message templates in the primary language of the recipient, the message generation module 210 can determine whether there are any message templates in the set of message templates that are in another language understood by the recipient, as shown at 418. If so, the message template in the other language is retrieved from the message template database 230, as shown at 420. If there are no message templates in a language that is understood by the recipient, a default message template can be retrieved from the message template database 230, as shown at 422.
[0040] At 424, the message generation module 210 can generate the outgoing message based on the retrieved message template and the recipient preferences. As described above, the message generation module 210 can format specific values received in the message data in accordance with the recipient preferences of the recipient.
[0041] It is appreciated that the foregoing technique 400 is provided for example only and not intended to be limiting. Variations of the technique 400 are contemplated and are within the scope of the disclosure.
[0042] Example embodiments are provided so that this disclosure will be thorough, and will fully convey the scope to those who are skilled in the art. Numerous specific details are set forth such as examples of specific components, devices, and methods, to provide a thorough understanding of embodiments of the present disclosure. It will be apparent to those skilled in the art that specific details need not be employed, that example embodiments may be embodied in many different forms and that neither should be construed to limit the scope of the disclosure. In some example embodiments, well-known procedures, well-known device structures, and well-known technologies are not described in detail.
[0043] The terminology used herein is for the purpose of describing particular example embodiments only and is not intended to be limiting. As used herein, the singular forms "a," "an," and "the" may be intended to include the plural forms as well, unless the context clearly indicates otherwise. The term "and/or" includes any and all combinations of one or more of the associated listed items. The terms "comprises," "comprising," "including," and "having," are inclusive and therefore 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. The method steps, processes, and operations described herein are not to be construed as necessarily requiring their performance in the particular order discussed or illustrated, unless specifically identified as an order of performance. It is also to be understood that additional or alternative steps may be employed.
[0044] Although the terms first, second, third, etc. may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections should not be limited by these terms. These terms may be only used to distinguish one element, component, region, layer or section from another region, layer or section. Terms such as "first," "second," and other numerical terms when used herein do not imply a sequence or order unless clearly indicated by the context. Thus, a first element, component, region, layer or section discussed below could be termed a second element, component, region, layer or section without departing from the teachings of the example embodiments.
[0045] As used herein, the term module may refer to, be part of, or include: an Application Specific Integrated Circuit (ASIC); an electronic circuit; a combinational logic circuit; a field programmable gate array (FPGA); a processor or a distributed network of processors (shared, dedicated, or grouped) and storage in networked clusters or datacenters that executes code or a process; other suitable components that provide the described functionality; or a combination of some or all of the above, such as in a system-on-chip. The term module may also include memory (shared, dedicated, or grouped) that stores code executed by the one or more processors.
[0046] The term code, as used above, may include software, firmware, byte- code and/or microcode, and may refer to programs, routines, functions, classes, and/or objects. The term shared, as used above, means that some or all code from multiple modules may be executed using a single (shared) processor. In addition, some or all code from multiple modules may be stored by a single (shared) memory. The term group, as used above, means that some or all code from a single module may be executed using a group of processors. In addition, some or all code from a single module may be stored using a group of memories.
[0047] The techniques described herein may be implemented by one or more computer programs executed by one or more processors. The computer programs include processor-executable instructions that are stored on a non- transitory tangible computer readable medium. The computer programs may also include stored data. Non-limiting examples of the non-transitory tangible computer readable medium are nonvolatile memory, magnetic storage, and optical storage.
[0048] Some portions of the above description present the techniques described herein in terms of algorithms and symbolic representations of operations on information. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. These operations, while described functionally or logically, are understood to be implemented by computer programs. Furthermore, it has also proven convenient at times to refer to these arrangements of operations as modules or by functional names, without loss of generality.
[0049] Unless specifically stated otherwise as apparent from the above discussion, it is appreciated that throughout the description, discussions utilizing terms such as "processing" or "computing" or "calculating" or "determining" or "displaying" or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system memories or registers or other such information storage, transmission or display devices.
[0050] Certain aspects of the described techniques include process steps and instructions described herein in the form of an algorithm. It should be noted that the described process steps and instructions could be embodied in software, firmware or hardware, and when embodied in software, could be downloaded to reside on and be operated from different platforms used by real time network operating systems.
[0051] The present disclosure also relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored on a computer readable medium that can be accessed by the computer. Such a computer program may be stored in a tangible computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus. Furthermore, the computers referred to in the specification may include a single processor or may be architectures employing multiple processor designs for increased computing capability.
[0052] The algorithms and operations presented herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems may also be used with programs in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatuses to perform the required method steps. The required structure for a variety of these systems will be apparent to those of skill in the art, along with equivalent variations. In addition, the present disclosure is not described with reference to any particular programming language. It is appreciated that a variety of programming languages may be used to implement the teachings of the present disclosure as described herein, and any references to specific languages are provided for disclosure of enablement and best mode of the present invention. [0053] The present disclosure is well suited to a wide variety of computer network systems over numerous topologies. Within this field, the configuration and management of large networks comprise storage devices and computers that are communicatively coupled to dissimilar computers and storage devices over a network, such as the Internet.
[0054] The foregoing description of the embodiments has been provided for purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure. Individual elements or features of a particular embodiment are generally not limited to that particular embodiment, but, where applicable, are interchangeable and can be used in a selected embodiment, even if not specifically shown or described. The same may also be varied in many ways. Such variations are not to be regarded as a departure from the disclosure, and all such modifications are intended to be included within the scope of the disclosure.

Claims

CLAIMS What is claimed is:
1 . A computer-implemented method, comprising:
receiving, at a message server having one or more processors, a request to generate an outgoing message for one or more recipients, the request including one or more recipient indicators indicating the one or more recipients, a message type identifier identifying a type of outgoing message to be generated, and message data indicating values for generating the outgoing message; and for each one of the one or more recipients indicated by the one or more recipient indicators:
a) retrieving, at the message server, one or more recipient preferences of the one recipient from a recipient preferences database, the one or more recipient preferences relating to customization of messages that are to be delivered to the one recipient, and including one or more languages understood by the one recipient, and least one of a date format preference of the one recipient, a measurement unit preference of the one recipient, and a currency preference of the one recipient, a number formatting preference of the one recipient, a time formatting preference of the one recipient, a time-zone preference of the one recipient, and a language dialect preference of the one recipient;
b) retrieving, at the message server, a message template from a plurality of message templates stored in a message template database based on the message template identifier and one of the one or more languages understood by the one recipient;
c) generating, at the message server, the outgoing message based on the retrieved message template, the message data, and the one or more recipient preferences of the one recipient; and
d) providing, from the message server, the outgoing message to the one recipient.
2. A computer-implemented method, comprising:
receiving, at a message server having one or more processors, a request to generate an outgoing message for a recipient;
retrieving, at the message server, one or more recipient preferences of the recipient from a recipient preferences database, the one or more recipient preferences relating to customization of messages that are to be delivered to the recipient and including one or more languages understood by the recipient, including a primary language of the recipient;
retrieving, at the message server, a message template from a plurality of message templates stored in a message template database based on the request and the one or more recipient preferences;
generating, at the message server, the outgoing message based on the retrieved message template and the one or more recipient preferences; and
providing, from the message server, the outgoing message to the recipient.
3. The method of claim 2, wherein the retrieving the message template further comprises:
determining whether any of the plurality of message templates stored in the message template database are in the primary language, and when one of the plurality of message templates is in the primary language, identifying the one message template as the message template.
4. The method of claim 3, further comprising:
when none of the plurality of message templates are in the primary language, determining another language of the recipient from the one or more languages understood by the recipient;
determining whether any of the plurality of message templates stored in the message template database are in the other language; and
when one of the plurality of message templates is in the other language, identifying the one message template as the message template.
5. The method of claim 3, wherein:
the request includes a message type identifier identifying a type of outgoing message to be generated, and
the plurality of message templates includes a set of message templates corresponding to the message type identifier, such that each message template in the set of message templates is in a different language.
6. The method of claim 2, wherein the one or more recipient preferences include at least one of a date format preference of the recipient, a measurement unit preference of the recipient, and a currency preference of the recipient.
7. The method of claim 2, wherein:
requests are received from a plurality of different applications,
each different application of the plurality of different applications has a different set of message templates in the plurality of message templates corresponding thereto, and
the retrieving the message template is further based on the application providing the request.
8. The method of claim 2, wherein the request indicates a plurality of message recipients including the recipient and each one of the message recipients has specific recipient preferences corresponding thereto.
9. The method of claim 8, further comprising, for each one of the plurality of recipients, retrieving the specific recipient preferences corresponding to the one recipient, retrieving a specific message template based on the request and the specific recipient preferences of the one recipient, generating a specific outgoing message based on the specific message template and the specific recipient preferences of the one recipient, and providing the specific outgoing message to the one recipient.
10. The method of claim 2, wherein the request includes message data provided by a requestor of the personalized message, wherein the outgoing message is generated using the message data.
1 1 . The method of claim 10, further comprising:
when the message data includes additional text to be included in the outgoing message and when the additional text is not in one of the one or more languages that are understood by the user, obtaining a machine translation of the additional text into one of the one or more languages to obtain translated text, and inserting the translated text in the outgoing message.
12. A computer-implemented system, comprising:
a recipient preferences database that stores recipient preferences of a plurality of message recipients, wherein the recipient preferences of each one of the plurality of message recipients relate to customization of messages that are for the one message recipient and include one or more languages understood by the one recipient, including a primary language of the one recipient;
a message template database that stores a plurality of message templates; and
a message generation module that is configured to:
i) receive a request to generate an outgoing message for a recipient, the request indicating the recipient and message data for generating the outgoing message,
retrieve one or more recipient preferences of the recipient from the recipient preferences database, iii) retrieve a message template from a message template database based on the request and the one or more recipient preferences,
iv) generate the outgoing message based on the retrieved message template and the one or more recipient preferences, and
provide the outgoing message to the recipient.
13. The system of claim 12, wherein the message generation module is further configured to determine whether any of the plurality of message templates stored in the message template database are in the primary language, and when one of the plurality of message templates is in the primary language, identify the one message template as the message template.
14. The system of claim 12 wherein the message generation module is further configured to, when none of the plurality of message templates are in the primary language:
determine another language of the recipient from the one or more languages understood by the recipient;
determine whether any of the plurality of message templates stored in the message template database are in the other language; and
when one of the plurality of message templates is in the other language, identify the one message template as the message template.
15. The system of claim 12, wherein,
the request includes a message type identifier identifying a type of outgoing message to be generated, and
the plurality of message templates includes a set of message templates corresponding to the message type identifier, such that each message template in the set of message templates is in a different language.
16. The system of claim 12, wherein the one or more recipient preferences include at least one of a date format preference of the recipient, a measurement unit preference of the recipient, and a currency preference of the recipient.
17. The system of claim 12, wherein:
the message generation module receives requests from a plurality of different applications,
each different application of the plurality of different applications has a different set of message templates in the plurality of message templates corresponding thereto, and the message template is retrieved further based on the application providing the request.
18. The system of claim 12, wherein the request indicates a plurality of message recipients including the recipient and each one of the message recipients has specific recipient preferences corresponding thereto.
19. The system of claim 12 wherein:
the request includes message data provided by a requestor of the personalized message, and
the outgoing message is generated based on the message data.
20. The method of claim 19, wherein the message generation module is further configured to:
determine whether the message data includes additional text to be included in the outgoing message;
when the message data includes the additional text to be included in the outgoing message, determine whether the additional text is in one of the one or more languages that are understood by the recipient, and
when the additional text is not in one of the one or more languages that are understood by the user, obtain translated text by obtaining a machine translation of the additional text into one of the one or more languages and insert the translated text in the outgoing message.
PCT/US2013/021403 2012-01-16 2013-01-14 Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient WO2013109494A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
EP13700839.7A EP2805442A4 (en) 2012-01-16 2013-01-14 Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient
KR1020147022595A KR102050982B1 (en) 2012-01-16 2013-01-14 Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient
CN201380005644.3A CN104170293B (en) 2012-01-16 2013-01-14 For the method and system of the language based on recipient, internationalization and localization preference generation outgoing message

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US13/351,031 US9268762B2 (en) 2012-01-16 2012-01-16 Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient
US13/351,031 2012-01-16

Publications (1)

Publication Number Publication Date
WO2013109494A1 true WO2013109494A1 (en) 2013-07-25

Family

ID=47595108

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2013/021403 WO2013109494A1 (en) 2012-01-16 2013-01-14 Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient

Country Status (5)

Country Link
US (2) US9268762B2 (en)
EP (1) EP2805442A4 (en)
KR (1) KR102050982B1 (en)
CN (1) CN104170293B (en)
WO (1) WO2013109494A1 (en)

Families Citing this family (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9720899B1 (en) 2011-01-07 2017-08-01 Narrative Science, Inc. Automatic generation of narratives from data using communication goals and narrative analytics
CN102752398B (en) * 2012-07-18 2015-09-09 腾讯科技(深圳)有限公司 The method of resolution flow value, terminal, server and system
WO2014076525A1 (en) 2012-11-16 2014-05-22 Data2Text Limited Method and apparatus for expressing time in an output text
US20150371266A1 (en) * 2013-10-06 2015-12-24 Shocase, Inc . System and method for delivering certain work posted on a social network to a targeted audience
US10069775B2 (en) * 2014-01-13 2018-09-04 Adobe Systems Incorporated Systems and methods for detecting spam in outbound transactional emails
US10564614B2 (en) 2014-01-31 2020-02-18 Vivint, Inc. Progressive profiling in an automation system
US11044114B2 (en) * 2014-01-31 2021-06-22 Vivint, Inc. Rule-based graphical conversational user interface for security and automation system
US10691872B2 (en) * 2014-03-19 2020-06-23 Microsoft Technology Licensing, Llc Normalizing message style while preserving intent
WO2016018004A1 (en) 2014-07-31 2016-02-04 Samsung Electronics Co., Ltd. Method, apparatus, and system for providing translated content
US11922344B2 (en) 2014-10-22 2024-03-05 Narrative Science Llc Automatic generation of narratives from data using communication goals and narrative analytics
KR20160059069A (en) * 2014-11-17 2016-05-26 삼성전자주식회사 Apparatus and method for managing message
US9985922B2 (en) * 2015-05-29 2018-05-29 Globechat, Inc. System and method for multi-langual networking and communication
US10320724B2 (en) 2015-08-28 2019-06-11 International Business Machines Corporation Message assistant via smart templates
US10469436B2 (en) * 2015-11-20 2019-11-05 Accenture Global Solutions Limited Managing messaging services
US10686745B2 (en) * 2015-12-28 2020-06-16 Facebook, Inc. Systems and methods for providing messages based on preconfigured messages templates
CN105635464A (en) * 2015-12-30 2016-06-01 厦门欣欣信息有限公司 Message processing method and apparatus
US11328706B2 (en) * 2016-07-21 2022-05-10 Oslabs Pte, Ltd. System and method for multilingual conversion of text data to speech data
JP6767224B2 (en) * 2016-09-29 2020-10-14 株式会社東芝 Communication devices, communication methods, and communication programs
US10467347B1 (en) 2016-10-31 2019-11-05 Arria Data2Text Limited Method and apparatus for natural language document orchestrator
US11568148B1 (en) 2017-02-17 2023-01-31 Narrative Science Inc. Applied artificial intelligence technology for narrative generation based on explanation communication goals
US11954445B2 (en) 2017-02-17 2024-04-09 Narrative Science Llc Applied artificial intelligence technology for narrative generation based on explanation communication goals
US10547577B2 (en) * 2017-03-28 2020-01-28 Whatsapp Inc. Techniques for templated messages
CN106997343A (en) * 2017-03-28 2017-08-01 联想(北京)有限公司 Information processing method and equipment
US10922483B1 (en) 2017-08-04 2021-02-16 Grammarly, Inc. Artificial intelligence communication assistance for providing communication advice utilizing communication profiles
US10963649B1 (en) 2018-01-17 2021-03-30 Narrative Science Inc. Applied artificial intelligence technology for narrative generation using an invocable analysis service and configuration-driven analytics
US10755046B1 (en) 2018-02-19 2020-08-25 Narrative Science Inc. Applied artificial intelligence technology for conversational inferencing
CN110474832B (en) * 2018-05-09 2022-02-25 深圳市尚云互联技术有限公司 Message pushing method and application system thereof
US11334726B1 (en) * 2018-06-28 2022-05-17 Narrative Science Inc. Applied artificial intelligence technology for using natural language processing to train a natural language generation system with respect to date and number textual features
US11089147B2 (en) * 2018-06-29 2021-08-10 Google Llc Systems, devices, and methods for generating messages
CN110908744B (en) * 2018-09-17 2023-07-07 福建天泉教育科技有限公司 Message multilingual support method for instant messaging software system and storage medium
CN110413574B (en) * 2019-07-30 2023-04-07 深圳市携众通科技有限公司 Method for automatically generating code internationalized resources
CN111190667A (en) * 2019-12-05 2020-05-22 航天信息股份有限公司 Multi-language message service setting method and system
CN112818654B (en) * 2021-02-18 2024-02-02 北京奇艺世纪科技有限公司 Message storage method, message generation method, device, electronic equipment and computer readable medium

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090281829A1 (en) * 2008-05-08 2009-11-12 Exco Intouch Systems, Methods and Computer Program Products for Providing Compliant Messaging Services
US7720922B2 (en) * 2006-12-11 2010-05-18 Digital River, Inc. Email content builder system and method

Family Cites Families (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA1280215C (en) * 1987-09-28 1991-02-12 Eddy Lee Multilingual ordered data retrieval system
JP3129778B2 (en) * 1991-08-30 2001-01-31 富士通株式会社 Vector quantizer
JPH0981569A (en) * 1995-09-12 1997-03-28 Hitachi Ltd System for providing services handling many countries
US5884246A (en) * 1996-12-04 1999-03-16 Transgate Intellectual Properties Ltd. System and method for transparent translation of electronically transmitted messages
US5960382A (en) * 1997-07-07 1999-09-28 Lucent Technologies Inc. Translation of an initially-unknown message
US6161082A (en) 1997-11-18 2000-12-12 At&T Corp Network based language translation system
US6623529B1 (en) * 1998-02-23 2003-09-23 David Lakritz Multilingual electronic document translation, management, and delivery system
US6088699A (en) * 1998-04-22 2000-07-11 International Business Machines Corporation System for exchanging compressed data according to predetermined dictionary codes
FI116992B (en) * 1999-07-05 2006-04-28 Nokia Corp Methods, systems, and devices for enhancing audio coding and transmission
US7171348B2 (en) * 1999-09-10 2007-01-30 Worldlingo.Com Pty Ltd Communication processing system
US20010029455A1 (en) * 2000-03-31 2001-10-11 Chin Jeffrey J. Method and apparatus for providing multilingual translation over a network
US7873533B2 (en) * 2000-04-21 2011-01-18 Accolo, Inc. Comprehensive employment recruiting communications system with translation facility
US20020173946A1 (en) * 2001-03-28 2002-11-21 Christy Samuel T. Translation and communication of a digital message using a pivot language
US20030115552A1 (en) * 2001-11-27 2003-06-19 Jorg Jahnke Method and system for automatic creation of multilingual immutable image files
US7853557B2 (en) * 2002-06-14 2010-12-14 Siebel Systems, Inc. Method and computer for responding to a query according to the language used
US7072880B2 (en) * 2002-08-13 2006-07-04 Xerox Corporation Information retrieval and encoding via substring-number mapping
GB2395029A (en) 2002-11-06 2004-05-12 Alan Wilkinson Translation of electronically transmitted messages
WO2004049110A2 (en) 2002-11-22 2004-06-10 Transclick, Inc. Language translation system and method
US6917914B2 (en) * 2003-01-31 2005-07-12 Harris Corporation Voice over bandwidth constrained lines with mixed excitation linear prediction transcoding
US8027438B2 (en) * 2003-02-10 2011-09-27 At&T Intellectual Property I, L.P. Electronic message translations accompanied by indications of translation
US20060152479A1 (en) * 2005-01-10 2006-07-13 Carlson Michael P Intelligent text magnifying glass in camera in telephone and PDA
US20070067154A1 (en) * 2005-09-22 2007-03-22 International Business Machines Corporation Language translation system
EP1775655B1 (en) * 2005-10-14 2015-08-19 BlackBerry Limited Automatic language selection for improving text accuracy
US8239184B2 (en) * 2006-03-13 2012-08-07 Newtalk, Inc. Electronic multilingual numeric and language learning tool
WO2007139910A2 (en) * 2006-05-26 2007-12-06 Laden Sondrah S System and method of language translation
US20080288252A1 (en) * 2007-03-07 2008-11-20 Cerra Joseph P Speech recognition of speech recorded by a mobile communication facility
US9785916B2 (en) * 2007-10-12 2017-10-10 Yahoo Holdings, Inc. Integrating rich media into a web-based calendar
US20090234633A1 (en) 2008-03-17 2009-09-17 Virginia Chao-Suren Systems and methods for enabling inter-language communications
US7933930B1 (en) * 2008-04-08 2011-04-26 United Services Automobile Association (Usaa) Systems and methods for creating documents from templates
US8249857B2 (en) * 2008-04-24 2012-08-21 International Business Machines Corporation Multilingual administration of enterprise data with user selected target language translation
US20100017466A1 (en) * 2008-06-17 2010-01-21 Douglas Trauner System and method for dynamic processing of measurement metrics and tagging measurement metrics
EP2261818A1 (en) 2009-06-09 2010-12-15 Dudu Communications FZ-LLC A method for inter-lingual electronic communication
US9607290B2 (en) * 2010-03-24 2017-03-28 Worldmate, Ltd. Apparatus and method for detecting messages in a parsing process
US8392508B2 (en) * 2010-06-11 2013-03-05 International Business Machines Corporation Selectively controlling information flow in a collaborative environment
US8352507B2 (en) * 2010-10-29 2013-01-08 Microsoft Corporation Retrieval and storage of localized instances of data objects
US8885569B2 (en) * 2011-12-19 2014-11-11 Ofinno Technologies, Llc Beamforming signaling in a wireless network

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7720922B2 (en) * 2006-12-11 2010-05-18 Digital River, Inc. Email content builder system and method
US20090281829A1 (en) * 2008-05-08 2009-11-12 Exco Intouch Systems, Methods and Computer Program Products for Providing Compliant Messaging Services

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP2805442A4 *

Also Published As

Publication number Publication date
EP2805442A4 (en) 2015-09-30
CN104170293B (en) 2018-07-06
US20130185051A1 (en) 2013-07-18
US9268762B2 (en) 2016-02-23
CN104170293A (en) 2014-11-26
US20160217120A1 (en) 2016-07-28
KR102050982B1 (en) 2020-01-08
KR20140117536A (en) 2014-10-07
US9747271B2 (en) 2017-08-29
EP2805442A1 (en) 2014-11-26

Similar Documents

Publication Publication Date Title
US9747271B2 (en) Techniques for generating outgoing messages based on language, internationalization, and localization preferences of the recipient
Pierce et al. Efficient design for Mendelian randomization studies: subsample and 2-sample instrumental variable estimators
JP6246951B2 (en) Data settings for user contact entries
US9256674B2 (en) Action clustering for news feeds
KR102277624B1 (en) Provision of translation of electronic messages through social network systems
US20180032499A1 (en) Automatically Generating Spelling Suggestions and Corrections Based on User Context
US20120278404A1 (en) Upload of attachment and insertion of link into electronic messages
US20220150665A1 (en) System and Method for Requesting an Updated User Location
CN106462565A (en) Updating text within a document
US20120233268A1 (en) Publish/subscribe message routing
US20150365411A1 (en) Systems and methods for creating and displaying an electronic communication digest
CN111159557B (en) Hot spot information acquisition method, device, server and medium
US20190164108A1 (en) Merging data securely from different sources
US20160299954A1 (en) Processing a search query and ranking results from a database system of a network communication software
US20150156153A1 (en) Collaborative e-mail
US10674476B1 (en) Contextual aware electronic alert system
US9521087B1 (en) Servicing requests using multiple data release cycles
US10320731B2 (en) System and method for threading electronic messages
US8712761B2 (en) Techniques for performing translation of messages
Krishnamoorthy et al. Tolerance intervals for the distribution of the difference between two independent normal random variables
US20180034764A1 (en) Selecting applications for message handling
Weinberg Invited commentary: can issues with reproducibility in science be blamed on hypothesis testing?
WO2015200113A1 (en) Automatic identification and use of alternate user contact information
US11025570B2 (en) Dynamic and secure real-time notifications in messages
Bhattacharjee et al. On SPRT and RSPRT for the unknown mean in a normal distribution with equal mean and variance

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 13700839

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 20147022595

Country of ref document: KR

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2013700839

Country of ref document: EP