This application is a 35 U.S.C. 371 National Stage Application of International Application No. PCT/CN2012/077888, filed Jun. 29, 2012, the entire contents of which are incorporated herein by reference.
This disclosure relates to the technical field of computer input.
The continued proliferation of computing devices has led to an increase in the availability of applications and other content used on these devices. For instance, users employ a variety of applications, such as word processing applications, business applications, communication applications, games, digital media players, browsers, and numerous other types of applications, on an assortment of computing devices. As the number of computing devices and applications used on these devices continues to increase, users are ever more interested in enhancing their experiences while using these computing devices and applications.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Some implementations provide techniques and arrangements for semantic lexicon based processing, such as in an input method editor. In some instances, a semantic label may be received that is to be defined for a semantic lexicon and at least a first term may be identified as a positive or negative example of the semantic label. In response, some examples may label at least a second term in the semantic lexicon with the semantic label based at least in part on the identification of the first term as a positive or negative example of the semantic label.
The detailed description is set forth with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items or features.
Overview
This disclosure includes techniques and arrangements for semantic lexicon based processing. In some implementations, techniques and arrangements are provided for establishing and using a semantic lexicon with an input method editor (IME) that provides completion candidates to a user for insertion into another computer application. In some examples, an IME may be a computer application that assists a user to input text to a computing device. An IME may provide several completion candidates based on inputs received from the user. The user may then select one or more of the completion candidates and, in response to the selection, the IME inserts the selected completion candidates into another computer application.
In some examples that involve an IME, the disclosed techniques provide an IME that provides candidates to a user to input into a computer application at least partly based on a semantic lexicon and the queries input by the user. In some situations, the candidates may include not only text candidates, such as non-Latin characters, e.g., Chinese, and Latin characters, e.g., English, but also rich candidates, such as multimedia, to provide supplemental information to a user to enhance the user experience.
The queries may be one or more texts such as characters or symbols input by the user. The queries may represent one or more expressions. For example, a query may be a series of initial characters, an abbreviation, a spelling, and/or a translation of one or more words or phrases. The queries and the expressions represented by the queries, such as words or phrases, may be in the same or different languages. The user may input the queries through a variety of input methods such as a keyboard input, a voice input, a touch screen input or a gesture input.
Candidates and their rankings for display positions among multiple candidates may also be generated or identified based on a combination of parameters for a current user input. For example, a same query input by the user into the IME with different semantic lexicons or in different scenarios may have different candidates and/or candidate rankings. In some implementations, the ranking of the candidates may also be different for different users with different semantic lexicon labeling. The scenario of the user input may include a scenario of the computer application (e.g., chatting or emailing). The scenario of the user input may also include a context of the user input (e.g., a prior use history of the computing application such as chatting history or contents displayed at the user interface of the computer application such as the user's prior inputs).
In some implementations, the IME may provide rich candidates in some predefined scenarios of the user input (such as emailing or chatting) and not provide rich candidates in some predefined scenarios of the user input (such as document editing). In another implementation, the IME may provide rich candidates when a probability that a rich candidate is desired by the user is calculated to be beyond a predefined threshold.
There may also be various configurations for the deployment of the IME. In one implementation, all components of the IME are located at a client device. In another implementation, the IME is implemented in a client-server architecture in which some components are located at the client device and some components are located at the remote server relative to the client device.
Example Implementations
A user of computing device 102, via a user interface of an input method editor (IME) 104, inputs one or more objects 106 into a user interface of a computer application 108. Both the user interface of the IME 104 and the user interface of the computer application 108 are presented in a user interface of the computing device 102 at a same time. There may be two or more computer applications (not shown in
In the example of
The input window 112 includes input objects 114 that are to be input into the chatting window 110 as objects 106. In the example of
The user may use the user interface of the IME 104 to input the input objects 114. In the example of
The query 118 and the text candidates 120 may be any kind of text such as Latin characters (e.g. English), non-Latin characters (e.g. Chinese), symbols, numbers, or a mix of different kinds of texts. The query 118 and the text candidates 120 may be the same language or different languages. For example, the query 118 may represent a series of initial characters, an abbreviation, a spelling, and/or a translation of the text candidates 120.
The rich candidates 122 may include pictures, maps, videos, and/or other forms of representations in addition to texts. The rich candidates 122 may include, for example, pictures, maps, videos, or other forms of representations that provide supplemental information to the user in addition to the text candidates 120.
In the example of
As mentioned above, to assist in determining the completion candidates to present, the IME may refer to a semantic lexicon as well as collect data relating to the scenario of the user input. Regarding the semantic lexicon, the IME 104 may access a semantic lexicon and determine, among other things, whether the query includes any terms that are semantically labeled within the semantic lexicon, such as a term labeled as a place. Regarding the scenario, the scenario of the user input includes the scenario of the computer application 108, i.e. chatting in
The query 118 in the example of
The text candidate window 126 displays identified text candidates 120. In the example of
The text candidate window 126 may display more text candidates 120 if the user clicks the button 130 for more text candidates 120.
The rich candidate window 128 displays the identified or generated rich candidates 122. In the example of
In some implementations, the web services are online services, such as Bing® map, that do not require a registration of the user to use. The IME 104 may directly use the query 118, semantic labeling and/or the scenario of user input as input parameters to request the web service to return the rich candidates 122. In another implementation, the web service (not shown in
The user may select one or more of the text candidates 120 and/or rich candidates 122 as input objects 114 to be inserted at the input indication 116.
Specifically, a user is utilizing an IME 202 to input completion candidates into a chatting program 204. In the example shown in
For the rich candidates, the IME 202 refers to the semantic lexicon and determines that the term “Transformers” is a movie title and that, in combination with the phrase “preview of,” there is a high probability that the user is interested in seeing a preview or trailer of the film “Transformers.” Based on this determination, the IME 202 may use web video search services, such as those found on web search engines like Microsoft Bing®, to search for videos relating to the film “Transformers.” Thus, in
Other implementations may not involve an IME, but rather use the semantic lexicon described herein in other programs. It should be understood that, though this disclosure may, for ease of understanding, describes the system and method in the context of an IME, the system and method described herein are not limited to such uses and may be used in many other situations.
The semantic lexicon functionality described herein may be implemented at various levels in the software and hardware of computing systems. Such levels include the Operating System (OS) level, such as in the OS with or without application support, the application level, either separate from OS (i.e. stand-alone) or as a plug-in to the OS or a plug-in to another application and so forth. Further, the semantic lexicon functionality may be implemented universally for all applications, such as in OS only implementations, or the functionality may only be active in select situations, either in specific programs (e.g. a OS level IME), classes of programs (e.g. dedicated IMEs of individual programs), and so forth. Moreover, some implementations may allow a user to set various parameters of the semantic lexicon functionality such as, the class of programs that implement the functionality, the languages, writing systems, and rich candidate types to be used for the functionality and so forth.
In implementations that involve an IME, various application configurations may be installed at the IME. In one example, some applications are installed at the IME in an executable file format. In another example, the IME may use a file in a form of declarative markup language, such as the Extensible Markup Language (XML), to describe one or more characteristics of the one or more applications associated with the IME. The markup language file is human-readable and editable, and is called a manifest or manifest file herein. The manifest file is a self-describing document. It is the starting point when loading a respective application, and is interpreted by the computing system of the IME, such as at a client device and/or a server in a declarative way to enable application behaviors. It is also used to automatically expose configuration information about the respective application. In client-server implementations, the manifest file may reside at both the client and the server components of the computing system of the IME.
The manifest file may include a manifest schema and a manifest. The manifest schema, which is in the form of declarative markup language, describes the manifest features supported by the computing system of the IME. The manifest describes a particular application. The features in the manifest for the particular application shall comply with the specification in the manifest schema. The manifest for the particular application may be an independent file from the manifest schema. Alternatively, the manifests for different applications and the manifest schema may be combined in one manifest file. The manifest schema may expose enumerations for supported scenarios. An application developer of the applications may refer to the manifest schema as a baseline reference to the current capability of the computing system of the IME.
The Identity element 302 describes an application that is to be used in the case of a rich candidate being triggered. In the example illustrated in
The LikelihoodQuickCheck element 304 provides the probabilities for different combination of parameters such as input and context conditions that the identified application be considered a contender for a given query. Particularly, it may declare or calculate “scores” for different inputs. In short, it has a language for leveraging semantic labeling in a regular expression-like syntax.
The Engine element 306 declares whether the engine of the application is located at the client device, a server device, or both. In the example illustrated in
The display element 308 declares how the computing system of the IME will display this particular application. It may take into consideration scenarios of different host applications and describes how to transform the presentation according to the scenarios. In this way, the host application may have influence on how candidates are displayed. In the example illustrated in
The insertion element 310 declares how to transform the data from the chosen candidate into a form the host application can accept and declares whether the candidate can be transformed “optimally” into the host application according to the scenario. For example, an email candidate might be transformed into a special email link in an email program, or plain text in a simple note taking program. In the example illustrated in
Returning to the LikelihoodQuickCheck element 304,
At block 402, the IME 104 receives a query including user input. This query could include text entered into the user interface of the IME 104 shown in
At block 404, the IME 104 determines if the input, or a portion thereof, is a term that has a semantic label. The IME 104 then determines if any manifests, such as that shown in
At block 406, the assigned scores are used to select candidates for inclusion in the candidates windows 126 and 128. If necessary, the selected candidates are then generated. The process flow 400 then continues to block 408.
At block 408, the selected candidates are displayed at the user interface of the IME 104 for selection by the user and insertion into the computer application 108.
At block 502, the lexicon is initialized. In some implementations, initializing the lexicon may involve loading a predefined set of terms to be used in the lexicon. For example, in some implementations, initializing the lexicon may involve loading a large set of terms and processing the set to remove terms which are deemed too common for usage in the lexicon. In other implementations, the initialized lexicon may be a generic list of terms, for example, a list of terms taken from an online dictionary. In still other implementations, the initialization of the lexicon may involve the loading of a set of terms that includes only a specific set of predefined terms. These and other variations on the terms included in the lexicon would be apparent to one of skill in the art in view of this disclosure. Following the initialization of the lexicon, the process flow 500 continues to block 504.
At block 504, information is collected and/or generated about the terms in the lexicon. In some example implementations, this is accomplished by the extraction of rich information for each term in the lexicon from an information source. Many kinds of information and information sources may be used, including structured or semi-structured data available on the Web. For example, the information could be extracted from sources such as the tags assigned to the terms on portal sites, the definitions of the terms in Wikipedia, and statistics for the terms determined based on among a huge collection of documents and/or web pages (such as contextual statistics, i.e. which other term co-occurs with the term for how many times). Once the information is collected or generated, process flow 500 moves to block 506.
At block 506, term relationships are established using the information generated at block 504. In some implementations, given the information about the terms generated in block 504, the relationship between each pair of terms is represented in some mathematical way. For example, if contextual statistics of each term is known from block 504, each term may be represented as a high-dimensional vector where each dimension corresponds to a different word that co-occurs with the term in the same sentence or document. The value assigned to each dimension is the frequency of co-occurrence of the terms. In other implementations, the term relationships may be determined based on how similarly the various terms “behave” in the base material. For example, the terms “Transformers” and “Inception” may be found to “behave” similarly because they are both movie titles. A non-limiting example of “behavior” as used herein is that both terms are found in similar usage contexts in the base material. More concretely, an example could be that, on some web sites, web pages are titled or directed at both “Transformers” and “Inception” in a similar context. In some implementations using a mathematical representation of term relationships, the strength of the relationship between the terms may then be defined as the distance between the two vectors.
It should be noted that there is a large variety of possible definitions and/or implementations of rich information and term relationships that would be apparent to one of skill in the art in view of this disclosure. However, implementations are not limited to any of these definitions and/or implementations.
Initially, a user provides a semantic label that is to be defined as well as a number of words, which are indicated as positive and/or negative examples of the label, to a client side user interface displayed by computing device 702. The semantic label and the examples are then submitted to the server side labeling system 704. This disclosure uses the terms positive and negative with respect to semantic labeling. Though not limited to such, an example of a concrete “positive” label is the labeling of “Austin” as a place. An example of a concrete “negative” label is the negative labeling of “tablet” regarding the label “place.” More simply, this may mean that, “tablet”, is not a place. In other words, a non-limiting meaning of a term being a “negative example” or “negatively labeled” herein is that the term does not “fit” within the label or is not correctly described by the label. Combining this, the term “Transformers” may have a positive labeling for the label “movie” but a negative labeling for the label “place.” Thus, “Transformer” is a “movie” but not a “place.” These examples and other variations would be apparent to one of skill in the art in view of this disclosure.
Based on the received label and examples, the label determination component 706 of the labeling system 704 labels other terms in the lexicon 708. The label determination component 706 also identifies those terms which are difficult to be labeled (i.e. marginal terms).
In some implementations, given the user-provided example terms, the labeling system operates to positively and negatively label other terms as based on the distance between the terms and the user-provided examples. Terms which are “closer,” for example, in the aforementioned term relationship map 600, to the user-provided positive example terms than the negative example terms will be labeled with the concerned semantic label. Those terms which are closer in the term relationship map to the user-provided negative example terms than the positive ones will be labeled as negative with regard to the concerned semantic label. In some implementations, the “closeness” between a term and the positive examples may be defined as the average of the distance between the term and each positive example. Similarly, the “closeness” between a term and the negative examples may be defined as the average of the distance between the term and each negative example. The degree of “closeness” that is defined as closer to positive examples as opposed to negative examples need not be measured equally. In other words, for a term to be labeled positively with respect to the label, it may have to be, for example, twice as “close” to the positive example terms as it is to the negative example terms in the aforementioned term relationship map 600.
As mentioned above, the label determination component 706 also identifies marginal terms. A marginal term may be a term where there is no significant difference between its distance from positive examples and its distance from negative examples. Upon determining the lack of a significant difference, the term may be selected as a marginal term. The label determination component 706 then sends the marginal terms 712 along with a tentative labeling of each to the computing device 702.
In response to receiving the marginal terms 712, the computing device 702 presents the marginal terms to the user along with the tentative labels. The user then confirms or negates the tentative labels. The user's responses for the marginal terms 714 are then submitted to the labeling system 704.
The process of labeling, including the identification of marginal terms, then obtaining user feedback for the marginal terms, is iterated until, for example, either the user explicitly terminates the process, the labeling system 704 finds that the user has confirmed some percentage or other number of the tentative labels, or there are no marginal terms remaining. In a particular example, the iterations may continue until the labeling system 704 determines that the label is “stable.” Such a stability determination could be based on the percentage of recently submitted tentative labels confirmed as correct by the user.
The labeling system then outputs the completed semantic label 716 to the lexicon storage 708 for incorporation into the lexicon. While shown as being performed upon completion for the establishment of a semantic label, the incorporation of the new semantic label may be performed in parallel with the process of establishing of the label.
Some modules of the labeling system 704 may be implemented as separate systems and their processing results can be used by the labeling system 704. For the sake of convenient description, the above functionally is divided into various modules which are separately described. When implementing the disclosed system, the functions of various modules may be implemented in one or more instances of software and/or hardware. Further, as mentioned above, the functionality need not be divided into a client-server architecture and may be, for instance, performed on a single device such as computing device 102.
At block 902, the labeling system 704 receives a semantic label to be defined as well as positive and negative example terms for the label. For ease of comprehension, consider the aforementioned case of the user providing a label for the lexicon of
At block 904, using term relationships, the labeling system 704 identifies other positive and negative terms in the lexicon with respect to the semantic label. The labeling system 704 also identifies marginal terms. For ease of comprehension, consider the aforementioned case of the label determination component 706 determining that term 602 and term 606 are both closer to term 604 than to term 608. As such, terms 602 and 606 labeled positively regarding the label. On the other hand, the label determination component 706 finds that term 610 is not significantly closer to either term 604 or term 608. This may be conducted in the manner discussed above with regard to
At block 906, the marginal terms are provided to the user of computing device 702 and feedback for the marginal terms is received. Using the feedback, the term labeling is updated. Referring to the example of
At block 908, the labeling system 704 determines whether a sufficient level of certainty has been obtained for the label. As discussed above, in some implementations, this may determined based on the number of marginal terms that remain unlabeled or the percentage of tentative labels being confirmed by the user. Other metrics could also be used to determine when sufficient certainty has been achieved for the semantic label. If sufficient certainty has been reached, the process flow continues to block 910. Otherwise, the process flow returns to block 904.
At block 910, the label determination component 706 outputs the semantic label in its complete form to the lexicon storage 708. The process flow 900 is then complete and the semantic label is ready for use.
The semantic lexicon which is generated by the implementations illustrated in
First, a minimal perfect hash function (MPHF) may be generated for the semantic lexicon. A MPHF provides a one-to-one mapping from each lexicon term to a corresponding integer without collision (i.e. from 0 to lexicon_count−1). The MPHF is then stored.
Second, the semantic lexicon is stored in a semantic lexicon file, SXF. Some implementations may use length-prefix strings to represent variant-length words in the semantic lexicon. In such implementations, the terms may be stored in the lexicon file as a sequence of Length (in binary)+words (in text). In some of these implementations, the offset of each term in the lexicon file may also be stored in an extra index file.
Third, the semantic labelings are stored in a semantic label file. There are many ways that the semantic labelings can be stored. Two examples are the use of length-prefix labels and the use of a fixed-size bitmap. The use of length-prefix labels is the same type of storage as discussed above regarding the semantic lexicon file. For the use of a fixed-size bitmap, if semantic labels of each term are predefined, then a bitmap can be created for each term. If the term belongs to a label, the corresponding bit will be set to 1. Otherwise, the bit will be set to 0.
In some implementations, all semantic label files share the same semantic lexicon file. Each semantic label file is assigned a unique ID. In operation, the IME client will use the unique ID to refer to the right semantic label file.
Having processed the semantic lexicon in the manner described above, the IME is now ready to use the semantic label of the semantic lexicon. Specifically, to use the semantic lexicon, at startup, the IME may load the MPHF data to construct the perfect hash function and then map the semantic lexicon file and the semantic label files to memory using file mapping technology. During operation, if the user or the IME wants to check the labels of a give word, the IME will use the MPHF to get the index of the word and then use the index to locate and return the semantic labels given in the semantic lexicon file.
While several examples have been illustrated herein for discussion purposes, numerous other configurations may be used and thus implementations herein are not limited to any particular configuration or arrangement. For example, as previously mentioned, the functionality provided by the disclosed techniques and arrangements are not limited to input method editors.
The discussion herein refers to data being sent and received by particular components or modules system. This should not be taken as a limitation as such communication need not be direct and the particular components or module need not necessarily be a single functional unit. For example, the label determination component 706 and lexicon storage 708 are discussed as separate logical components of the system which carry out separate functions and communicate with each other. This is not to be taken as limiting implementations to only those in which the components directly send and receive data from one another. The signals could instead be relayed by a separate component upon receipt of the data. Further, the components may be combined or the functionality may be separated amongst components in various manners not limited to those discussed above. Other variations in the logical and practical structure and framework of various implementations would be apparent to one of ordinary skill in the art in view of the disclosure provided herein.
The processes described herein are only examples provided for discussion purposes. Numerous other variations will be apparent to those of skill in the art in light of the disclosure herein. Further, while the disclosure herein sets forth several examples of suitable frameworks, architectures and environments for executing the techniques and processes herein, implementations herein are not limited to the particular examples shown and discussed. The processes illustrated herein are shown as a collection of operations in a logical flow graph, which represents a sequence of operations, some or all of which can be implemented in hardware, software or a combination thereof. In the context of software, the blocks represent computer-executable instructions stored on one or more computer-readable media that, when executed by one or more processors, perform the recited operations. Generally, computer-executable instructions include routines, programs, objects, components, data structures and the like that perform particular functions or implement particular abstract data types. The order in which the operations are described is not intended to be construed as a limitation. Any number of the described blocks can be combined in any order and/or in parallel to implement the process, and not all of the blocks need be executed.
Example Computing Device and Environment
The computing device 1000 may include at least one processor 1002, a memory 1004, communication interfaces 1006, a display device 1008 (e.g. a touchscreen display), other input/output (I/O) devices 1010 (e.g. a touchscreen display or a mouse and keyboard), and one or more mass storage devices 1012, able to communicate with each other, such as via a system bus 1014 or other suitable connection.
The processor 1002 may be a single processing unit or a number of processing units, all of which may include single or multiple computing units or multiple cores. The processor 1002 can be implemented as one or more microprocessors, microcomputers, microcontrollers, digital signal processors, central processing units, state machines, logic circuitries, and/or any devices that manipulate signals based on operational instructions. Among other capabilities, the processor 1002 can be configured to fetch and execute computer-readable instructions stored in the memory 1004, mass storage devices 1012, or other computer-readable media.
Memory 1004 and mass storage devices 1012 are examples of computer storage media for storing instructions which are executed by the processor 1002 to perform the various functions described above. For example, memory 1004 may generally include both volatile memory and non-volatile memory (e.g., RAM, ROM, or the like). Further, mass storage devices 1012 may generally include hard disk drives, solid-state drives, removable media, including external and removable drives, memory cards, flash memory, floppy disks, optical disks (e.g., CD, DVD), a storage array, a network attached storage, a storage area network, or the like. Both memory 1004 and mass storage devices 1012 may be collectively referred to as memory or computer storage media herein, and may be capable of storing computer-readable, processor-executable program instructions as computer program code that can be executed by the processor 1002 as a particular machine configured for carrying out the operations and functions described in the implementations herein.
The computing device 1000 may also include one or more communication interfaces 1006 for exchanging data with other devices, such as via a network, direct connection, or the like, as discussed above. The communication interfaces 1006 can facilitate communications within a wide variety of networks and protocol types, including wired networks (e.g., LAN, cable, etc.) and wireless networks (e.g., WLAN, cellular, satellite, etc.), the Internet and the like. Communication interfaces 1006 can also provide communication with external storage (not shown), such as in a storage array, network attached storage, storage area network, or the like.
A display device 1008, such as a touchscreen display or other display device, may be included in some implementations. Other I/O devices 1010 may be devices that receive various inputs from a user and provide various outputs to the user, and may include a touchscreen, such as touchscreen display, a keyboard, a remote controller, a mouse, a printer, audio input/output devices, and so forth.
Memory 1004 may include modules and components for the computing device 1000 according to the implementations discussed herein. In the illustrated example, memory 1004 includes the IME 104 and the computer application 108 as described above with regard to
The example systems and computing devices described herein are merely examples suitable for some implementations and are not intended to suggest any limitation as to the scope of use or functionality of the environments, architectures and frameworks that can implement the processes, components and features described herein. Thus, implementations herein are operational with numerous environments or architectures, and may be implemented in general purpose and special-purpose computing systems, or other devices having processing capability. Generally, any of the functions described with reference to the figures can be implemented using software, hardware (e.g., fixed logic circuitry) or a combination of these implementations. The term “module,” “mechanism” or “component” as used herein generally represents software, hardware, or a combination of software and hardware that can be configured to implement prescribed functions. For instance, in the case of a software implementation, the term “module,” “mechanism” or “component” can represent program code (and/or declarative-type instructions) that performs specified tasks or operations when executed on a processing device or devices (e.g., CPUs or processors). The program code can be stored in one or more computer-readable memory devices or other computer storage devices. Thus, the processes, components and modules described herein may be implemented by a computer program product.
Although illustrated in
Computer storage media includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other non-transmission medium that can be used to store information for access by a computing device.
In contrast, communication media may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave, or other transmission mechanism. As defined herein, computer storage media does not include communication media.
Furthermore, this disclosure provides various example implementations, as described and as illustrated in the drawings. However, this disclosure is not limited to the implementations described and illustrated herein, but can extend to other implementations, as would be known or as would become known to those skilled in the art. Reference in the specification to “one implementation,” “this implementation,” “these implementations” or “some implementations” means that a particular feature, structure, or characteristic described is included in at least one implementation, and the appearances of these phrases in various places in the specification are not necessarily all referring to the same implementation.
Conclusion
Although the subject matter has been described in language specific to structural features and/or methodological acts, the subject matter defined in the appended claims is not limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims. This disclosure is intended to cover any and all adaptations or variations of the disclosed implementations, and the following claims should not be construed to be limited to the specific implementations disclosed in the specification. Instead, the scope of this document is to be determined entirely by the following claims, along with the full range of equivalents to which such claims are entitled.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN2012/077888 | 6/29/2012 | WO | 00 | 9/14/2012 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2014/000263 | 1/3/2014 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4931935 | Ohira | Jun 1990 | A |
5995920 | Carbonell | Nov 1999 | A |
6070140 | Tran | May 2000 | A |
6289301 | Higginbotham et al. | Sep 2001 | B1 |
6822585 | Ni | Nov 2004 | B1 |
7383172 | Jamieson | Jun 2008 | B1 |
7778816 | Reynar | Aug 2010 | B2 |
7925610 | Elbaz | Apr 2011 | B2 |
8056007 | Rupp | Nov 2011 | B2 |
8228292 | Ruiz | Jul 2012 | B1 |
8457416 | Liu | Jun 2013 | B2 |
8788261 | Sikstrom | Jul 2014 | B2 |
8996356 | Yang | Mar 2015 | B1 |
9031830 | Ballinger et al. | May 2015 | B2 |
9361365 | Sweeney | Jun 2016 | B2 |
20020198909 | Huynh et al. | Dec 2002 | A1 |
20030149692 | Mitchell | Aug 2003 | A1 |
20030171913 | Maxwell, III | Sep 2003 | A1 |
20030182279 | Willows | Sep 2003 | A1 |
20050108195 | Yalovsky et al. | May 2005 | A1 |
20060088356 | Jawerth | Apr 2006 | A1 |
20060173674 | Nakajima et al. | Aug 2006 | A1 |
20070005343 | Sandor | Jan 2007 | A1 |
20070060114 | Ramer | Mar 2007 | A1 |
20070083359 | Bender | Apr 2007 | A1 |
20070100806 | Ramer | May 2007 | A1 |
20070124132 | Takeuchi | May 2007 | A1 |
20070156393 | Todhunter | Jul 2007 | A1 |
20080010274 | Carus | Jan 2008 | A1 |
20080115086 | Rupp | May 2008 | A1 |
20080171555 | Oh | Jul 2008 | A1 |
20080182598 | Bowman | Jul 2008 | A1 |
20080221878 | Collobert | Sep 2008 | A1 |
20080266148 | Chen | Oct 2008 | A1 |
20080270120 | Pestian | Oct 2008 | A1 |
20080275694 | Varone | Nov 2008 | A1 |
20080313607 | Yutaka | Dec 2008 | A1 |
20090052786 | Gross | Feb 2009 | A1 |
20090055732 | Motaparti | Feb 2009 | A1 |
20090083028 | Davtchev | Mar 2009 | A1 |
20090164455 | Weinberg | Jun 2009 | A1 |
20090326919 | Bean | Dec 2009 | A1 |
20100005086 | Wang | Jan 2010 | A1 |
20100088303 | Chen | Apr 2010 | A1 |
20100100568 | Papin | Apr 2010 | A1 |
20100332217 | Wintner | Dec 2010 | A1 |
20110093479 | Fuchs | Apr 2011 | A1 |
20110153324 | Ballinger | Jun 2011 | A1 |
20110153325 | Ballinger | Jun 2011 | A1 |
20110161080 | Ballinger | Jun 2011 | A1 |
20110161081 | Ballinger | Jun 2011 | A1 |
20110202874 | Ramer | Aug 2011 | A1 |
20110208511 | Sikstrom | Aug 2011 | A1 |
20110248914 | Sherr | Oct 2011 | A1 |
20110270604 | Qi | Nov 2011 | A1 |
20110285656 | Yaksick | Nov 2011 | A1 |
20110301941 | De Vocht | Dec 2011 | A1 |
20110314006 | Sweeney | Dec 2011 | A1 |
20110316772 | Zhang | Dec 2011 | A1 |
20110320548 | Jonsson | Dec 2011 | A1 |
20120016658 | Wu | Jan 2012 | A1 |
20120019446 | Wu | Jan 2012 | A1 |
20120029910 | Medlock | Feb 2012 | A1 |
20120042022 | Sheth | Feb 2012 | A1 |
20120065963 | Bangalore et al. | Mar 2012 | A1 |
20120117506 | Koch | May 2012 | A1 |
20120166182 | Ko | Jun 2012 | A1 |
20120203541 | Liu | Aug 2012 | A1 |
20120303452 | Xue | Nov 2012 | A1 |
20120330669 | Narayanan | Dec 2012 | A1 |
20130018874 | Qiao | Jan 2013 | A1 |
20130018894 | Qiao | Jan 2013 | A1 |
20130074076 | Lindenfeld | Mar 2013 | A1 |
20130096910 | Stan | Apr 2013 | A1 |
20130132871 | Zeng | May 2013 | A1 |
20130141259 | Hazarika | Jun 2013 | A1 |
20130159277 | Liu | Jun 2013 | A1 |
20130159919 | Leydon | Jun 2013 | A1 |
20130198623 | Claux | Aug 2013 | A1 |
20130246322 | De Sousa Webber | Sep 2013 | A1 |
20130290390 | Choe | Oct 2013 | A1 |
20130325436 | Wang | Dec 2013 | A1 |
20140143355 | Berdis | May 2014 | A1 |
20140195621 | Rao DV | Jul 2014 | A1 |
20140258905 | Lee | Sep 2014 | A1 |
20150088487 | Yang | Mar 2015 | A1 |
20150161110 | Salz | Jun 2015 | A1 |
20150169552 | Yang | Jun 2015 | A1 |
20150186362 | Li | Jul 2015 | A1 |
20150199332 | Li | Jul 2015 | A1 |
Entry |
---|
Jiang et al., “On the Development of Text Input Method—Lessons Learned”, retrieved at <<http://arxiv.org/ftp/arxiv/papers/0704/0704.3665.pdf>>, Apr. 2007, 10 pages. |
Choul-woong, Yeon., “Amharic (Ethiopian) Keyboard Released for iOS (iPhone) by Agerigna”, retrieved on Dec. 21, 2015 at <<http://www.koreaittimes.com/print/sotry/43996/amharicethiopian-keyboard-realeased-iosiphone-agerigna>>, Korea IT Times, published Jan. 10, 2015, pp. 1-3. |
Ellis, Jack., “Sogou's Assertion of Patents Against Baidu Could be a Landmark in the Evolution of China's IP Market”, retrieved on Dec. 21, 2015 at <<http://www.iam-media.com/blog/Detail.aspx?g=a8c43be5-0d30-4fea-a096-36a0d914b130>>, IAM, Oct. 30, 2015, pp. 1-2. |
“Entering Text with Word Prediction”, retrieved on Jan. 6, 2016 at <<http://www.htc.com/us/support/htc-one-s-t-mobile/howto/315363.html>>, HTC One S (T-Mobile), pp. 1-2. |
Goel, Vindu., “Facebook Announces a Payments Feature for Its Messenger App”, retrieved on Dec. 17, 2015 at <<http://nyti.ms/1GkgtCH>>, The New York Times, Mar. 17, 2015, pp. 1-4. |
Isaac, Mike, et al., “Facebook and Uber Follow Asian Rivals in Plan to Enhance Messenger App”, retrieved on Dec. 17, 2015 at <<http://nyti.ms/1P8xU0b>>, The New York Times, Dec. 16, 2015, pp. 1-4. |
Isaac, Mike., “Facebook Tests a Digital Assistant for Its Messaging App”, retrieved on Dec. 17, 2015 at <<http://bits.blogs.nytimes.com/2015/08/26/facebook-tests-a-digital-assistant-for-its-messaging-app/>>, The New York Times, Aug. 26, 2015, pp. 1-2. |
Lardinois, Frederic., “Google Brings More Than 100 Virtual Keyboards, Transliterations and IMEs to Gmail”, retrieved on Dec. 21, 2015 at <<http://techcrunch.com/2012/10/09/google-brings-more-than-100-virtual-keyboards-transliterations-and-imes-to-gmail/>>, TechCrunch, Oct. 9, 2012, pp. 1-8. |
Wortham, Jenna., “What Silicon Valley Can Learn From Seoul”, retrieved on Dec. 17, 2015 at <<http://www.nytimes.com/2015/06/07/magazine/what-silicon-valley-can-learn-from-seoul.html>>, The New York Times, Jun. 2, 2015, pp. 1-6. |
Amadeo, “2016 Google Tracker: Everything Google is working on for the next year,” retrieved on <<http://arstechnica.com/gadgets/2016/01/2016-google-tracker-everything-google-is-working-on-for-the-new-year/>> (Jan. 8, 2016) (last accessed Mar. 15, 2016) retrieved on Jul. 26, 2016, 4 pages. |
Apple, “Chinese Input Method: Use the Pinyin—Simplified Input Source,” retrieved at <<https://support.apple.com/kb/PH22620?locale=en_US>> (Sep. 30, 2015) (last accessed Jul. 18, 2016) retrieved on Jul. 26, 2016, 3 pages. |
Apple, IOS Developer Library, “Managing the Keyboard,” retrieved at <<https://developer.apple.com/library/prerelease/content/documentation/StringsTextFonts/Conceptual/TextAndWebiPhoneOS/KeyboardManagement/KeyboardManagement.html>> (Mar. 10, 2014) (last accessed Jul. 19, 2016) retrieved on Jul. 26, 2016, 9 pages. |
Eadicicco, “10 Ways Texting on Your iPhone is About to Change Forever,” Time, retrieved at <<http://time.com/4367056/apple-imessage-wwdc-ios-10-iphone/>> (Jun. 14, 2016) (last accessed Jul. 18, 2016) retrieved on Jul. 26, 2016, 4 pages. |
Facebook Draft.js, retrieved at <<https://github.com/facebook/draft-js.git>> (last accessed Mar. 24, 2016) retrieved on Jul. 26, 2016, 2 pages. |
Google Input Tools—Home, retrieved at <<https://www.google.com/inputtools/ >> (last visited Mar. 15, 2016) retrieved on Jul. 26, 2016, 2 pages. |
Google Input Tools—Supported Languages, retrieved at <<https://www.google.com/inputtools/help/languages.html>> (last visited Mar. 15, 2016) retrieved on Jul. 26, 2016, 7 pages. |
Google Play, “WeChat—Android Apps on Google Plan,” retrieved at <<https://play.google.com/store/apps/details?id=com.tencent.mm&referrer=utm_source%3Dwechat.com%26utm_medium%3Ddesktop>> (last visited Jan. 25, 2016) retreieved on Jul. 26, 2016, 3 pages. |
MDGB, Enabling pinyin input on your computer, retrieved at <<https://www.facebook.com/notes/mdbg/enabling-pinyin-input-on-your-computer/419757796861/>> (Sep. 4, 2010) (last accessed Mar. 23, 2016) retrieved on Jul. 26, 2016, 2 pages. |
Mozur, “Seeking Access to Facebook in China, Zuckerberg Courts Risks,” Nytimes, retrieved at <<http://www.nytimes.com/2016/03/21/business/seeking-access-to-facebook-in-china-zuckerberg-courts-risks.html>> (Mar. 20, 2016) (last accessed Mar. 23, 2016) retrieved on Jul. 26, 2016, 3 pages. |
Salier-Hellendag, “Facebook open sources rich text editor framework for Draft.js,” retrieved at <<https://code.facebook.com/posts/1684092755205505/facebook-open-sources-rich-text-editor-framework-draft-js/>> (Feb. 26, 2016) (last accessed Mar. 23, 2016). retrieved on Jul. 26, 2016, 10 pages. |
Sander, “Demo of Weixin/WeChat,” (published Apr. 18, 2013) retrieved at <<https://www.youtube.com/watch?v=AvpI0IZjDN8>> (accessed Jan. 24, 2016) retrieved on Jul. 26, 2016, 2 pages. |
WeChat, retrieved at <<http://www.wechat.com/en/ . . . (last visited Jan. 25, 2016), retrieved on Jul. 26, 2016, 2 pages. |
Weixin, “WeChat—Free messaging and calling app,” retrieved at <<http://weixin.qq.com/>> (as translated by google translate. Last visited Jan. 26, 2016) retrieved on Jul. 26, 2016, 3 pages. |
Number | Date | Country | |
---|---|---|---|
20150121290 A1 | Apr 2015 | US |