WO2014204659A2 - Building conversational understanding systems using a toolset - Google Patents
Building conversational understanding systems using a toolset Download PDFInfo
- Publication number
- WO2014204659A2 WO2014204659A2 PCT/US2014/041023 US2014041023W WO2014204659A2 WO 2014204659 A2 WO2014204659 A2 WO 2014204659A2 US 2014041023 W US2014041023 W US 2014041023W WO 2014204659 A2 WO2014204659 A2 WO 2014204659A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- domain
- intent
- service
- application
- sentences
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/40—Processing or translation of natural language
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/30—Semantic analysis
- G06F40/35—Discourse or dialogue representation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/38—Creation or generation of source code for implementing user interfaces
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10L—SPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
- G10L15/00—Speech recognition
- G10L15/08—Speech classification or search
- G10L15/18—Speech classification or search using natural language modelling
Definitions
- Conversational understanding (CU) systems are used for a variety of different applications.
- CU systems have been developed to allow users to search for content, buy items, obtain directions, and the like.
- the CU development process uses experts, such as scientists and computational linguists, in each step of the CU building process. For example, experts are used in the labeling of the data used when creating a CU application.
- CU Conversational Understanding
- the tools and assets are provided to allow developers to enable applications for CU and to interact with and extend the CU service.
- the tools include a variety of different tools, such as, but not limited to: labeling tools, training tools, validation tools, and the like.
- the tools may be used to select coverage from existing domains, extend the coverage of one or more domains, as well as to create new domains in the CU service. For example, a developer may select one or more Application Programming Interfaces (APIs) from one or more existing domains (e.g., weather, finance, news, sports ...) in the CU service to include in an application.
- APIs Application Programming Interfaces
- a developer may provide example Natural Language (NL) sentences that are analyzed by the tools to assist the developer in labeling data that is used to update the models in the CU service.
- the tools may assist a developer in identifying domains, determining intent actions, determining intent objects and determining slots from example NL sentences.
- the tools automatically determine possible labels for the example NL sentences and allow the user to create new domains, intent actions, intent objects and slots.
- the tools may be used by a developer to add their own tags for intent and slots or select automatically determined tags.
- the models in the CU service are automatically updated and validated. For example, validation tools may be used to determine an accuracy of the model against test data.
- FIGURE 1 illustrates a system that includes tools for a developer to create applications to interact with a conversational understanding service
- FIGURE 2 shows an exemplary graphical user interface for labeling example NL sentences
- FIGURE 3 shows a process for using tools to create an application to interact with a conversational understanding service
- FIGURE 4 shows a process for automatically detecting domains, actions, and objects from example natural language sentences to build customized models by mixing and matching domain models, intent models, or slot models or combining the underlying data to train new models;
- FIGURE 5 shows a process for adding or updating a domain that is associated with a conversational understanding system
- FIGURE 6 shows an example table of using existing domains to add a new domain to a conversational understanding system by re-using intents (or intent actions and/or objects) from existing domains;
- FIGURE 7 illustrates a conversational understanding system interacting with an application using functionality created by a developer using provided tools
- FIGURE 8 illustrates an exemplary online system that provides tools for developing a conversational understanding application
- FIGURES 9, 1 OA, 10B and 11 and the associated descriptions provide a discussion of a variety of operating environments in which embodiments of the invention may be practiced.
- FIGURE 1 illustrates a system that includes tools for a developer to create applications to interact with a conversational understanding service.
- system 100 includes Conversational Understanding (CU) service 105, development manager 26, Application Programmer Interfaces (APIs) 120, models 140, data 150, labeling tools 160, training tools 170, validation tools 180, application 110 and touch screen input device 115.
- CU service 105 Natural Language Understanding
- NLU Natural Language Understanding
- a goal-oriented CU service such as CU service 105
- NL natural language
- users often request flight information (e.g., "I want to fly to Boston from New York next week").
- Development manager 26 is configured to provide tools that assist a developer in developing and building applications to interact with CU service 105.
- the tools include a variety of different tools, such as, but not limited to: labeling tools 160, training tools 170, validation tools 180, and the like.
- the different tools may be used to select coverage from existing domains, extend one or more domains, as well as to create new domains for interacting with a CU service.
- a developer may select one or more Application Programming Interfaces (APIs) 120 from one or more existing domains (e.g., weather, finance, news, sports ...) in CU service 105 that are accessed by an application.
- APIs Application Programming Interfaces
- a domain is an area that is associated with a set of actions (e.g., movie domain, music domain, book domain, game domain, flight domain...) for which the CU service is trained to understand. Domains are typically related to a specific area but may also include more than one area.
- a developer may also extend a domain or create a new domain in CU service 105 using the tools.
- a fixed number of existing models 140 is updated to reflect the newly added domain.
- the models include a domain model, an intent action model, an intent object model and a slot model.
- new models may be created when a new domain is added.
- Data 150 includes data relating to creating and enabling an application for Conversational Understanding.
- the application interacts with CU service 105.
- data 150 may include training data that is used to train the models of CU service 105, one or more schemas relating to CU service 105, example data (e.g. example NL sentences) used to extend an existing domain or create a new domain in CU service 105, and the like.
- data such as training data, can be shared across domains and intents. For example, training data for intent actions may be common across a variety of different domains.
- Labeling tools 160 may be used by the developer to assist in labeling the data for the desired domains, intents and slots.
- the labeling tools 160 may be used by a developer to add their own tags for intent and slots.
- a developer may provide example NL sentences that are analyzed by the labeling tools to assist the developer in determining what existing domains, intent actions, intent objects, and slots to use as well as how to incorporate additional coverage into CU service 105.
- Labeling tools 160 automatically determine possible labels for the example NL sentences and allow the user to create new domains, intent actions, intent objects and slots.
- the tools may be used by a developer to add their own tags for intent and slots or select automatically determined tags.
- the labeling tools 160 may use domain detector 122, intent action detector 123, intent object detector 124 and slot tagging component 125.
- Domain detector 122 identifies the domains from different NL sentences. For example, a developer may provide example NL sentences that they would like coverage for in the CU service. Domain detector 122 may identify a single domain or multiple domains from the examples. For example, domain detector 122 may identify both a movie domain and a social domain from one example NL sentence and identify a movie domain from another example NL sentence. The domains that are detected from the examples may or may not already be supported by CU service 105. The results of domain detector 122 may be displayed in graphical user interface (GUI) 112.
- GUI graphical user interface
- Intent action detector 123 is configured to predict the intent action for the current example NL sentence.
- An intent action is the action to be performed (e.g. find, post, play, buy .%) in the example NL sentence.
- intent action detector 123 may predict the intent action for a current NL sentence to be: a get action; a find action; a post action; a play action; and the like.
- the predicted intent action may be displayed to the developer in GUI 112 to determine if the predicted intent action is the desired action.
- intent object detector 124 For each determined intent action, one or more intent objects are identified by intent object detector 124.
- An intent object is an object that relates to that determined intent action.
- the intent object is the object of the determined intent action (e.g. movie, picture, item).
- the results of intent object detector 124 may be displayed in graphical user interface (GUI) 112.
- the intent i.e. the combination of the intent action and intent object
- the intent is determined from the current example NL sentence.
- Slot tagging is performed by slot tagging component 125 using the determined domains, intent actions, and intent objects. Generally, slot tagging identifies what slots are associated with the words of a NL sentence.
- the example NL sentences may be automatically tagged using the predictions and then corrected by the developer when determined. For example, a developer may use GUI 112 to change the tagging.
- the results of slot tagging component 125 may be displayed in graphical user interface (GUI) 112.
- Training tools 170 include different tools that can be used to update the models of CU service 105. For example, a developer may select a training tool to update one or more of the models with additional training data.
- Validation tools 180 may be used by a developer to determine the accuracy of the updated models. For example, the validation tools 180 may be used to compare the results that are obtained using the models with expected results. The validation tools 180 may also be used by the developer to see if individual examples are processed correctly. The results may be corrected (e.g., by changing labels) when the validation tools 180 indicate that the results are not correct.
- application program 110 is a multimodal application that is configured to receive speech input and input from a touch-sensitive input device 115 or other input devices. For example, voice input, keyboard input (e.g., a physical keyboard and/or SIP), video based input, and the like. Application program 110 may also provide multimodal output (e.g., speech, graphics, vibrations, sounds ). Development manager 26 may provide information to/from application 110 in response to user input (e.g., speech, gesture). For example, a user may say a phrase to identify a task to perform by application 110 (e.g., selecting a movie, buying an item, identifying a product ).
- user input e.g., speech, gesture
- a user may say a phrase to identify a task to perform by application 110 (e.g., selecting a movie, buying an item, identifying a product ).
- Gestures may include, but are not limited to: a pinch gesture; a stretch gesture; a select gesture (e.g., a tap action on a displayed element); a select and hold gesture (e.g., a tap and hold gesture received on a displayed element); a swiping action and/or dragging action; and the like.
- Gestures may also include optically captured gestures, such as: a wave gesture, a scroll gesture, a guide gesture, and the like.
- a device such as MICROSOFT KINECT may be used to detect gestures.
- System 100 as illustrated comprises a touch screen input device 115 that detects when a touch input has been received (e.g., a finger touching or nearly teaching the touch screen). Any type of touch screen may be utilized that detects a user's touch input. More details are provided below.
- FIGURE 2 shows an exemplary graphical user interface for labeling example NL sentences.
- FIGURE 2 shows graphical user interface (GUI) 200 that includes a current NL example sentence 205, a domain section 210, an intent action 220 section, an intent object 230 section, and a slot 240 section.
- GUI graphical user interface
- the CU service includes a set of models including a domain model, one or more intent models and a slot model that are trained for one or more domains.
- a domain model For purposes of explanation, the following example relates to a CU service that is trained for four different domains, including a Game domain, a Movie domain, a Music domain, and a Generic Commands domain.
- the data that is used to train the models for the CU service is annotated.
- labeling tools can be used by a developer to assist in labeling the data used to update the models.
- example NL sentences that relate to sports and possibly other domains.
- the example NL sentences are sentences that are illustrative of how a user would interact with the application being developed.
- the domains may include information that relates to a Sports domain, a Weather domain, a Movie domain, a Generic Commands domain, and the like.
- Each of the example NL sentences submitted by the developer can be processed by labeling tools. Additional NL sentences may also be automatically generated using the example NL sentences.
- the example NL sentences may be rephrased using a sentence rephrasing tool that automatically generates an enriched list of sentences which contain different ways of expressing the same meaning as the example NL sentences.
- GUI 200 shows the processing of the example NL sentence 205 "Show me Kobe Bryant jump shot pictures”.
- Domain section 210 shows results from running a domain detector on example NL sentence 205.
- the domain detector may be automatically run or manually run.
- the developer may select domain option 212 to run the domain detector.
- the domain detector identifies the domains from the available domains in the CU service that relate to the example NL sentence 205 and a confidence score for the domain.
- the confidence score provides an indication to a developer as to whether or not the domain is correctly identified for the example NL sentence.
- the confidence score ranges between 0 and 1, where a higher score indicates that the domain is more related to the example NL sentence as compared to a lower score.
- the developer can pick one of the suggested domains (e.g., by selecting the displayed box next to the domain) or add their own domain by selecting the add Domain option 214. In the current example, the developer has added a new "Sports" domain.
- Intent Action section 220 shows results from running an intent action detector on example NL sentence 205.
- the intent action detector may be automatically run or manually run.
- the developer may select intent action option 222 to run the intent action detector.
- the most likely intent actions e.g., top N results
- the developer may also select the see examples option 226 to see example NL sentences that use the displayed intent action labels that are already included in the models.
- the developer can compare the example NL sentence to the example sentences and decide to pick one of the suggested intent actions or the developer can choose to add his own intent action to label the example NL sentence.
- the user may select the add intent action option 224.
- Intent Object section 230 shows results from running an intent object detector on the example NL sentence 205.
- the intent object detector may be automatically run or manually run.
- the developer may select intent object option 232 to run the intent object detector.
- the most likely intent objects e.g., top N results
- the developer may also select the see examples option 236 to view example NL sentences that use the displayed intent object labels that are already included in the model.
- the developer can compare the example NL sentence to the example sentences and decide to pick one of the suggested intent objects or the developer can choose to add his own intent object to label the example NL sentence.
- the user may select the add intent object option 234.
- Slot section 240 shows results from slot tagging the entities in example NL sentence 205.
- the slot tagging may be automatically run or manually run.
- the developer may select slot tagging option 242 to run the slot tagging.
- different detected slots e.g., the top N results
- the developer may also select the see examples 246 option to view similar slots that are already included in the model.
- the developer can either pick what is suggested or choose to highlight the sequences in the sentence and assign a new slot name by selecting the add new slot option 244. In the current example, the developer has created a new "Athlete" slot.
- the platform After performing the above steps for one or more of the sentences the platform automatically updates the models to make better suggestions to the developer for the next set of example NL sentences.
- FIGURES 3-5 illustrate a process for using tools to build a conversational understanding system.
- routines presented herein it should be appreciated that the logical operations of various embodiments are implemented (1) as a sequence of computer implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system. The implementation is a matter of choice dependent on the performance requirements of the computing system implementing the invention.
- FIGURE 3 shows a process for using tools to create an application to interact with a conversational understanding service.
- the process 300 moves to operation 310, where the tools to develop and enable a CU application are displayed.
- Tools are provided to allow developers to build applications to interact with Conversational Understanding (CU) systems and services.
- the tools include a variety of different tools, such as, but not limited to: selecting API tools, labeling tools, training tools, validation tools, and the like.
- the tools may be used to select functionality from existing domains, extend one or more domains, as well as to create new domains.
- the tools are used to determine what domains to use in the application as well as the corresponding APIs for the application.
- a domain detector may be used to identify the existing domains in the CU service that relate to the application being developed.
- a user may also select one or more existing APIs that are associated with one or more domains.
- decision operation 330 a determination is made as to whether there is an update to a domain or whether a domain is to be added to the CU system. When there is not either an update to a domain or a domain is not to be added, the process flows to operation 350. When there is an update to a domain or a domain is to be added, the process flows to operation 340.
- the tools are used to update and validate the models.
- labeling tools, training tools and validation tools may be used by the developer to update the CU service to include coverage for the application that is being developed.
- the models in the CU system are used by the application.
- the models may be used by one or more applications.
- FIGURE 4 shows a process for automatically detecting domains, actions, and objects from example natural language sentences to build customized models by mixing and matching domain models, intent models, or slot models or combining the underlying data to train new models.
- example NL sentences are received.
- the example NL sentences may be received in different forms.
- the examples may be in a form of sentences or utterances.
- an example NL sentence may be "find the most recent torn cruise movie”.
- Another example may be "post this link on social network site X”.
- a domain is an area that is associated with a set of actions (e.g. movie domain, music domain, book domain, game domain, flight domain).
- Zero or more domains may be detected depending on the domains that are already included in the domain model of the CU service.
- a domain model may initially include one domain (e.g. movies) that is then extended to include another domain (e.g. social). More domains may be added or removed from the domain model. In the examples provided above, two different domains may be detected (e.g. movie and social).
- the output of the domain detection is used to determine the intent action(s) that are associated with each of the detected domains.
- One or more intent actions may be detected.
- An intent action is an action to be performed (e.g. find, post, play, buy .).
- the intent actions detected include "find" and "post".
- the detected domains may or may not be used to assist in detecting any intent actions.
- the intent action domain may tag different intent actions according to the domain(s) the intent action is associated with. For example, the intent action "find” may be associated with many different domains (e.g. movie, games, books, flight, ...) whereas the intent action "post” may be associated with a single domain (e.g. social).
- the intent object(s) are detected. For each determined intent action, one or more intent objects are identified.
- An intent object is an object that relates to that determined intent action.
- the intent object is the object of the determined intent action (e.g. movie, picture, item).
- the intent objects detected include "movie” and "picture”.
- slot tagging is performed.
- the slots for the movie slot model include a ReleaseDate slot that is set to "most recent”, a MovieStar slot that is set to "torn cruise", a MovieType slot that is set to "movie”, and an ItemType slot that is set to "picture”.
- the slots for the social media slot model include and a SocialMedia slot that is set to "X”.
- Other domains may include other types of slots.
- a travel domain may comprise slots for departure location, departure time, arrival time, arrival destination, travel method, constraints (e.g., lowest cost, no layovers, etc.).
- a dining domain may comprise slots for cuisine type, time, party size, reservation needed, and relative location (e.g., in walking distance, near a transit station, etc.).
- the developer may add one or more slots to a slot model.
- the slot model for the travel domain may not include a slot for the travel method.
- the developer may create a new slot.
- models for the CU system are updated or customized. According to an embodiment, new models may be trained.
- FIGURE 5 shows a process for adding or updating a domain that is associated with a conversational understanding system.
- a domain to update or add to a CU service is determined.
- One or more models may be updated or created.
- four models are updated including a domain model, an intent action model, an intent object model and a slot model.
- two new models are created when a domain is added.
- the domain model is updated with the new domain to add.
- the understanding system currently supports four different domains (movies, music, games and generic commands) and that a sport domain is to be added.
- the existing domain model is updated to detect the new Sports domain when language relating to the Sports domain is located within a NL sentence.
- the intent action model is updated to support any new intent actions that are not already included in the intent action model.
- Many intent actions associated with the new domain may already be supported by the intent action model before being updated. For example, "get” and “find” intent actions that are associated with the sports domain may already be supported by the intent action model.
- Zero or more intent actions may be added to the intent action model (e.g. "schedule" ).
- the intent object model is updated to support any new intent objects that are not already included in the intent object model.
- Many intent objects associated with the new domain may already be supported by the intent object model before being updated.
- the intent objects already supported may include "game”, “photos", "person information”.
- Zero or more intent objects may be added to the intent object model (e.g. "news” ).
- the slot model is updated to support the new domain.
- a single slot model is used to support the domains.
- the slots may be associated with one or more different domains, actions and intents.
- FIGURE 6 shows an example table of using existing domains to add a new domain to a conversational understanding system by re-using intents (or intent actions and/or objects) from existing domains.
- the models in the example CU service are trained using four different domains including a Movie domain, a Music domain, a Games domain and a Generic Commands domain. More or less domains may be used to train the models.
- a developer wants to add a new Sports domain to the CU service.
- the developer supplies example NL sentences.
- the tools predict an intent action and an intent object.
- Table 600 includes an example NL sentence column, a predicted intent action column, a true intent action column, a predicted intent object column, a true intent object column, and a predicted intent column. Table 600 shows four example NL sentences. [0069] As can be seen by referring to table 600, the predicted intent actions are accurately predicted even though the sports domain is not part of the current CU service. In the current example, the predicted intent actions are the same as the true intent actions. The predicted intent objects are not as accurately predicted as compared to the intent actions, but they are reasonable.
- the "game" intent object label from the Games domain is predicted as each of the first two NL sentences is related to a game or match.
- the third NL sentence example shares the intent action and intent object with existing domains and is correctly predicted.
- FIGURE 7 illustrates a conversational understanding system interacting with an application using functionality created by a developer using provided tools.
- system 700 includes input manager 710, language understanding component 720, dialog engine 730, response generator 740, and application 770.
- Application 770 is an application that is configured to interact with CU service 705 and was developed using the tools as described herein.
- Application 770 may include a natural user interface (NUI) or some other interface to interact with CU service 705.
- NUI natural user interface
- a combination of a natural language dialog and other non-verbal modalities of expressing intent e.g., gestures, touch, gaze, images, videos, spoken prosody, etc.
- CU service 705 receives speech utterances from application 770 and is configured to have a dialog with a user.
- Input manager 710 is configured to receive input (the user dialog act) from application 770.
- the user dialog act may be different types of user input.
- the user dialog act may be speech input (e.g., an utterance), touch input, gesture input, text input, as well as other types of input.
- Input manager 710 may include different components, such as an Automatic Speech Recognizer (ASR), a gesture recognizer, a handwriting recognizer, and the like.
- ASR Automatic Speech Recognizer
- the speech is recognized by input manager 710 using ASR.
- Input manager 710 outputs text that is delivered to language understanding component 720.
- Language understanding component 720 is configured to receive and analyze the text. Generally, language understanding component 720 associates a meaning to the words of the text. For example, language understanding component 720 may tag the text, perform a syntactic analysis of the text, and the like. The language understanding component 720 is traditionally a rules based component that converts natural language sentences into semantic representations.
- Dialog engine 730 manages the dialog by determining a machine action in response to the user dialog act. Dialog engine 730 computes possible dialog states using dialog state computation component 732. Dialog manager 734 determines the machine action or machine actions. The dialog state information that is used by dialog manager 734 includes information for the current turn in the dialog as well as information for one or more past turns in the dialog. Dialog engine 730 provides the determined machine action to response generator 740.
- Response generator 740 determines what type of response to provide the user. For example, response generator 740 may determine to provide a spoken response to the user or a visual response to the user. For example, a Text-to-Speech ("TTS") component may output the response as synthesized speech when determined. Response generator 740 provides the response to the input to application 770.
- TTS Text-to-Speech
- FIGURE 8 illustrates an exemplary online system that provides tools for developing a conversational understanding application.
- system 1000 includes service 1010, data store 1045, tools 1046, touch screen input device 1050 (e.g., a slate), smart phone 1030 and display device 1080.
- service 1010 data store 1045
- tools 1046 touch screen input device 1050 (e.g., a slate)
- touch screen input device 1050 e.g., a slate
- service 1010 is a cloud based and/or enterprise based service that may be configured to provide services, such as dialog services as described herein.
- the service may be interacted with using different types of input and output.
- a user may use speech input, touch input, hardware based input, and the like.
- Functionality of one or more of the services provided by service 1010 may also be configured as a client server based application.
- service 1010 is a multi-tenant service that provides resources 1015 and services to any number of tenants (e.g., Tenants 1-N).
- Multi-tenant service 1010 is a cloud based service that provides resources 1015 to tenants subscribed to the service and maintains each tenant's data separately and protected from other tenant data.
- System 1000 as illustrated comprises a touch screen input device 1050 (e.g., a slate device) and smart phone 1030 that detects when a touch input has been received (e.g., a finger touching or nearly touching the touch screen). Any type of touch screen may be utilized that detects a user's touch input.
- the touch screen may include one or more layers of capacitive material that detects the touch input.
- the touch screen is configured to detect objects that in contact with or above a touchable surface.
- IR Infrared
- the touch screen may be configured to determine locations of where touch input is received (e.g., a starting point, intermediate points and an ending point). Actual contact between the touchable surface and the object may be detected by any suitable means, including, for example, by a vibration sensor or microphone coupled to the touch panel.
- sensors to detect contact includes pressure-based mechanisms, micro-machined accelerometers, piezoelectric devices, capacitive sensors, resistive sensors, inductive sensors, laser vibrometers, and LED vibrometers.
- smart phone 1030, touch screen input device 1050, and device 1080 are configured with multimodal input and output and each include an application (1031, 1051, 1081) that interact with service 1010 and were developed using tools 1046.
- touch screen input device 1050, smart phone 1030, and display device 1080 shows exemplary displays 1052, 1032, and 1082 showing the use of an application.
- Data may be stored on a device (e.g., smart phone 1030, touch screen input device 1050 and/or at some other location (e.g., network data store 1045).
- Data store 1045, or some other store may be used to store models, as well as other data.
- the applications used by the devices may be client based applications, server based applications, cloud based applications or some combination.
- display device 1080 is a device such as a MICROSOFT XBOX coupled to a display.
- Development manager 26 is configured to perform operations relating to processes as described herein. Development manager 26 is configured to access tools 1046 that are used by a developer to create an application to interact with service 1010. While manager 26 is shown within service 1010, the functionality of the manager may be included in other locations (e.g., on smart phone 1030 and/or touch screen input device 1050 and/or device 1080).
- the embodiments and functionalities described herein may operate via a multitude of computing systems including, without limitation, desktop computer systems, wired and wireless computing systems, mobile computing systems (e.g., mobile telephones, netbooks, tablet or slate type computers, notebook computers, and laptop computers), hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, and mainframe computers.
- mobile computing systems e.g., mobile telephones, netbooks, tablet or slate type computers, notebook computers, and laptop computers
- hand-held devices e.g., multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, and mainframe computers.
- embodiments and functionalities described herein may operate over distributed systems (e.g., cloud-based computing systems), where application functionality, memory, data storage and retrieval and various processing functions may be operated remotely from each other over a distributed computing network, such as the Internet or an intranet.
- a distributed computing network such as the Internet or an intranet.
- User interfaces and information of various types may be displayed via on-board computing device displays or via remote display units associated with one or more computing devices. For example user interfaces and information of various types may be displayed and interacted with on a wall surface onto which user interfaces and information of various types are projected.
- Interaction with the multitude of computing systems with which embodiments of the invention may be practiced include, keystroke entry, touch screen entry, voice or other audio entry, gesture entry where an associated computing device is equipped with detection (e.g., camera) functionality for capturing and interpreting user gestures for controlling the functionality of the computing device, and the like.
- detection e.g., camera
- FIGURES 9-11 and the associated descriptions provide a discussion of a variety of operating environments in which embodiments of the invention may be practiced.
- FIGURES 9-11 are for purposes of example and illustration and are not limiting of a vast number of computing device configurations that may be utilized for practicing embodiments of the invention, described herein.
- FIGURE 9 is a block diagram illustrating physical components (i.e., hardware) of a computing device 1100 with which embodiments of the invention may be practiced.
- the computing device components described below may be suitable for the computing devices described above.
- the computing device 1100 may include at least one processing unit 1102 and a system memory 1104.
- the system memory 1104 may comprise, but is not limited to, volatile storage (e.g., random access memory), non-volatile storage (e.g., read-only memory), flash memory, or any combination of such memories.
- the system memory 1104 may include an operating system 1105 and one or more program modules 1106 suitable for running software applications 1120 such as the development manager 26.
- the operating system 1105 may be suitable for controlling the operation of the computing device 1100.
- embodiments of the invention may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system. This basic
- the computing device 1100 may have additional features or functionality.
- the computing device 1100 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape.
- additional storage is illustrated in FIGURE 9 by a removable storage device 1109 and a non-removable storage device 1110.
- program modules 1106 may perform processes including, but not limited to, one or more of the stages of the methods and processes illustrated in the figures.
- Other program modules may include electronic mail and contacts applications, word processing applications, spreadsheet applications, database applications, slide presentation applications, drawing or computer-aided application programs, etc.
- embodiments of the invention may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors.
- embodiments of the invention may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in FIGURE 9 may be integrated onto a single integrated circuit.
- SOC system-on-a-chip
- Such an SOC device may include one or more processing units, graphics units, communications units, system virtualization units and various application functionality all of which are integrated (or "burned") onto the chip substrate as a single integrated circuit.
- the functionality, described herein, with respect to the development manager 26 may be operated via application-specific logic integrated with other components of the computing device 1100 on the single integrated circuit (chip).
- Embodiments of the invention may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies.
- embodiments of the invention may be practiced within a general purpose computer or in any other circuits or systems.
- the computing device 1100 may also have one or more input device(s) 1112 such as a keyboard, a mouse, a pen, a sound input device, a touch input device, etc.
- the output device(s) 1114 such as a display, speakers, a printer, etc. may also be included.
- the aforementioned devices are examples and others may be used.
- the computing device 1100 may include one or more communication connections 1116 allowing communications with other computing devices 1118. Examples of suitable communication connections 1116 include, but are not limited to, RF transmitter, receiver, and/or transceiver circuitry;
- USB universal serial bus
- Computer readable media may include computer storage media.
- Computer storage media may include volatile and nonvolatile, removable and nonremovable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules.
- the system memory 1104, the removable storage device 1109, and the non-removable storage device 1110 are all computer storage media examples (i.e., memory storage.)
- Computer storage media may include RAM, ROM, electrically erasable read-only memory (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 article of manufacture which can be used to store information and which can be accessed by the computing device 1100. Any such computer storage media may be part of the computing device 1100.
- Computer storage media does not include a carrier wave or other propagated or modulated data signal.
- Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media.
- modulated data signal may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal.
- communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
- RF radio frequency
- FIGURES 1 OA and 1 OB illustrate a mobile computing device 1200, for example, a mobile telephone, a smart phone, a tablet personal computer, a laptop computer, and the like, with which embodiments of the invention may be practiced.
- a mobile computing device 1200 for implementing the embodiments is illustrated.
- the mobile computing device 1200 is a handheld computer having both input elements and output elements.
- the mobile computing device 1200 typically includes a display 1205 and one or more input buttons 1210 that allow the user to enter information into the mobile computing device 1200.
- the display 1205 of the mobile computing device 1200 may also function as an input device (e.g., a touch screen display).
- an optional side input element 1215 allows further user input.
- the side input element 1215 may be a rotary switch, a button, or any other type of manual input element.
- mobile computing device 1200 may incorporate more or less input elements.
- the display 1205 may not be a touch screen in some embodiments.
- the mobile computing device 1200 is a portable phone system, such as a cellular phone.
- the mobile computing device 1200 may also include an optional keypad 1235.
- Optional keypad 1235 may be a physical keypad or a "soft" keypad generated on the touch screen display.
- the output elements include the display 1205 for showing a graphical user interface (GUI), a visual indicator 1220 (e.g., a light emitting diode), and or an audio transducer 1225 (e.g., a speaker).
- GUI graphical user interface
- the mobile computing device 1200 incorporates a vibration transducer for providing the user with tactile feedback.
- the mobile computing device 1200 incorporates input and/or output ports, such as an audio input (e.g., a microphone jack), an audio output (e.g., a headphone jack), and a video output (e.g., a HDMI port) for sending signals to or receiving signals from an external device.
- FIGURE 10B is a block diagram illustrating the architecture of one embodiment of a mobile computing device. That is, the mobile computing device 1200 can incorporate a system 1202 (i.e., an architecture) to implement some embodiments.
- the system 1202 is implemented as a "smart phone" capable of running one or more applications (e.g., browser, e-mail, calendaring, contact managers, messaging clients, games, and media clients, players).
- the system 1202 is integrated as a computing device, such as an integrated personal digital assistant (PDA) and wireless phone.
- PDA personal digital assistant
- One or more application programs 1266 may be loaded into the memory 1262 and run on or in association with the operating system 1264.
- the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth.
- the system 1202 also includes a non-volatile storage area 1268 within the memory 1262.
- the non-volatile storage area 1268 may be used to store persistent information that should not be lost if the system 1202 is powered down.
- the application programs 1266 may use and store information in the non-volatile storage area 1268, such as e-mail or other messages used by an e-mail application, and the like.
- a synchronization application (not shown) also resides on the system 1202 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in the non-volatile storage area 1268 synchronized with corresponding information stored at the host computer.
- other applications may be loaded into the memory 1262 and run on the mobile computing device 1200, including the development manager 26 as described herein.
- the system 1202 has a power supply 1270, which may be implemented as one or more batteries.
- the power supply 1270 might further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries.
- the system 1202 may also include a radio 1272 that performs the function of transmitting and receiving radio frequency communications.
- the radio 1272 facilitates wireless connectivity between the system 1202 and the "outside world", via a
- communications carrier or service provider Transmissions to and from the radio 1272 are conducted under control of the operating system 1264. In other words, communications received by the radio 1272 may be disseminated to the application programs 1266 via the operating system 1264, and vice versa.
- the visual indicator 1220 may be used to provide visual notifications, and/or an audio interface 1274 may be used for producing audible notifications via the audio transducer 1225.
- the visual indicator 1220 is a light emitting diode (LED) and the audio transducer 1225 is a speaker.
- LED light emitting diode
- the LED may be programmed to remain on indefinitely until the user takes action to indicate the powered-on status of the device.
- the audio interface 1274 is used to provide audible signals to and receive audible signals from the user.
- the audio interface 1274 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation.
- the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below.
- the system 1202 may further include a video interface 1276 that enables an operation of an on-board camera to record still images, video stream, and the like.
- a mobile computing device 1200 implementing the system 1202 may have additional features or functionality.
- the mobile computing device 1200 may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape. Such additional storage is illustrated in FIGURE 10B by the non-volatile storage area 1268.
- Mobile computing device 1200 may also include peripheral device port 1230.
- Data/information generated or captured by the mobile computing device 1200 and stored via the system 1202 may be stored locally on the mobile computing device 1200, as described above, or the data may be stored on any number of storage media that may be accessed by the device via the radio 1272 or via a wired connection between the mobile computing device 1200 and a separate computing device associated with the mobile computing device 1200, for example, a server computer in a distributed computing network, such as the Internet.
- a server computer in a distributed computing network such as the Internet.
- data information may be accessed via the mobile computing device 1200 via the radio 1272 or via a distributed computing network.
- data/information may be readily transferred between computing devices for storage and use according to well-known data information transfer and storage means, including electronic mail and collaborative data/information sharing systems.
- FIGURE 11 illustrates an embodiment of an architecture of an exemplary system, as described above.
- Content developed, interacted with, or edited in association with the development manager 26 may be stored in different communication channels or other storage types.
- various documents may be stored using a directory service 1322, a web portal 1324, a mailbox service 1326, an instant messaging store 1328, or a social networking site 1330.
- the development manager 26 may use any of these types of systems or the like for enabling data utilization, as described herein.
- a server 1320 may provide the development manager 26 to clients.
- the server 1320 may be a web server providing the development manager 26 over the web.
- the server 1320 may provide the development manager 26 over the web to clients through a network 1315.
- the client computing device may be implemented as the computing device 1100 and embodied in a personal computer, a tablet computing device 1310 and/or a mobile computing device 1200 (e.g., a smart phone). Any of these embodiments of the client computing device 1100, 1310, and 1200 may obtain content from the store 1316.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Physics & Mathematics (AREA)
- General Health & Medical Sciences (AREA)
- Human Computer Interaction (AREA)
- Software Systems (AREA)
- Acoustics & Sound (AREA)
- Multimedia (AREA)
- Computer Security & Cryptography (AREA)
- User Interface Of Digital Computer (AREA)
- Stored Programmes (AREA)
- Machine Translation (AREA)
Abstract
Tools are provided to allow developers to enable applications for Conversational Understanding (CU) using assets from a CU service. The tools may be used to select functionality from existing domains, extend the coverage of one or more domains, as well as to create new domains in the CU service. A developer may provide example Natural Language (NL) sentences that are analyzed by the tools to assist the developer in labeling data that is used to update the models in the CU service. For example, the tools may assist a developer in identifying domains, determining intent actions, determining intent objects and determining slots from example NL sentences. After the developer tags all or a portion of the example NL sentences, the models in the CU service are automatically updated and validated. For example, validation tools may be used to determine an accuracy of the model against test data.
Description
BUILDING CONVERSATIONAL UNDERSTANDING SYSTEMS USING A
TOOLSET
BACKGROUND
[0001] Conversational understanding (CU) systems are used for a variety of different applications. For example, CU systems have been developed to allow users to search for content, buy items, obtain directions, and the like. The CU development process uses experts, such as scientists and computational linguists, in each step of the CU building process. For example, experts are used in the labeling of the data used when creating a CU application.
SUMMARY
[0002] 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 as an aid in determining the scope of the claimed subject matter.
[0003] Developers may build Conversational Understanding (CU) systems with the aid of assets and tools that are available in a CU service or platform. The tools and assets are provided to allow developers to enable applications for CU and to interact with and extend the CU service. The tools include a variety of different tools, such as, but not limited to: labeling tools, training tools, validation tools, and the like. The tools may be used to select coverage from existing domains, extend the coverage of one or more domains, as well as to create new domains in the CU service. For example, a developer may select one or more Application Programming Interfaces (APIs) from one or more existing domains (e.g., weather, finance, news, sports ...) in the CU service to include in an application. A developer may provide example Natural Language (NL) sentences that are analyzed by the tools to assist the developer in labeling data that is used to update the models in the CU service. For example, the tools may assist a developer in identifying domains, determining intent actions, determining intent objects and determining slots from example NL sentences. The tools automatically determine possible labels for the example NL sentences and allow the user to create new domains, intent actions, intent objects and slots. For example, the tools may be used by a developer to add their own tags for intent and slots or select automatically determined tags. After the developer tags all or a portion of the example NL sentences, the models in the CU service are automatically updated and
validated. For example, validation tools may be used to determine an accuracy of the model against test data.
BRIEF DESCRIPTION OF THE DRAWINGS
[0004] FIGURE 1 illustrates a system that includes tools for a developer to create applications to interact with a conversational understanding service;
[0005] FIGURE 2 shows an exemplary graphical user interface for labeling example NL sentences;
[0006] FIGURE 3 shows a process for using tools to create an application to interact with a conversational understanding service;
[0007] FIGURE 4 shows a process for automatically detecting domains, actions, and objects from example natural language sentences to build customized models by mixing and matching domain models, intent models, or slot models or combining the underlying data to train new models;
[0008] FIGURE 5 shows a process for adding or updating a domain that is associated with a conversational understanding system;
[0009] FIGURE 6 shows an example table of using existing domains to add a new domain to a conversational understanding system by re-using intents (or intent actions and/or objects) from existing domains;
[0010] FIGURE 7 illustrates a conversational understanding system interacting with an application using functionality created by a developer using provided tools;
[0011] FIGURE 8 illustrates an exemplary online system that provides tools for developing a conversational understanding application; and
[0012] FIGURES 9, 1 OA, 10B and 11 and the associated descriptions provide a discussion of a variety of operating environments in which embodiments of the invention may be practiced.
DETAILED DESCRIPTION
[0013] Referring now to the drawings, in which like numerals represent like elements, various embodiment will be described.
[0014] FIGURE 1 illustrates a system that includes tools for a developer to create applications to interact with a conversational understanding service.
[0015] As illustrated, system 100 includes Conversational Understanding (CU) service 105, development manager 26, Application Programmer Interfaces (APIs) 120, models 140, data 150, labeling tools 160, training tools 170, validation tools 180, application 110 and touch screen input device 115.
[0016] Generally, Natural Language Understanding (NLU) in a goal-oriented CU service, such as CU service 105, is directed at identifying the domain(s) and intent(s) of the user, as expressed in natural language (NL), and to extract associated arguments or slots. For example, in an airline domain, users often request flight information (e.g., "I want to fly to Boston from New York next week"). In the movie domain where users often search for movies using natural language and play them with natural language commands there are many different slot types (e.g., movie star, movie release date, movie rating, and the like). Traditional training of NLU systems uses queries that are manually labeled (domain, intent, and slots) by experts or automatically labeled and checked by an expert.
[0017] Development manager 26 is configured to provide tools that assist a developer in developing and building applications to interact with CU service 105. The tools include a variety of different tools, such as, but not limited to: labeling tools 160, training tools 170, validation tools 180, and the like.
[0018] The different tools may be used to select coverage from existing domains, extend one or more domains, as well as to create new domains for interacting with a CU service. For example, a developer may select one or more Application Programming Interfaces (APIs) 120 from one or more existing domains (e.g., weather, finance, news, sports ...) in CU service 105 that are accessed by an application. Generally, a domain is an area that is associated with a set of actions (e.g., movie domain, music domain, book domain, game domain, flight domain...) for which the CU service is trained to understand. Domains are typically related to a specific area but may also include more than one area. A developer may also extend a domain or create a new domain in CU service 105 using the tools.
[0019] According to an embodiment, for each domain that is added to a C U service, a fixed number of existing models 140 is updated to reflect the newly added domain.
According to an embodiment, the models include a domain model, an intent action model, an intent object model and a slot model. According to another embodiment, new models may be created when a new domain is added.
[0020] Data 150 includes data relating to creating and enabling an application for Conversational Understanding. According to an embodiment, the application interacts with CU service 105. For example, data 150 may include training data that is used to train the models of CU service 105, one or more schemas relating to CU service 105, example data (e.g. example NL sentences) used to extend an existing domain or create a new domain in CU service 105, and the like. According to an embodiment, data, such as
training data, can be shared across domains and intents. For example, training data for intent actions may be common across a variety of different domains.
[0021] Labeling tools 160 may be used by the developer to assist in labeling the data for the desired domains, intents and slots. For example, the labeling tools 160 may be used by a developer to add their own tags for intent and slots. A developer may provide example NL sentences that are analyzed by the labeling tools to assist the developer in determining what existing domains, intent actions, intent objects, and slots to use as well as how to incorporate additional coverage into CU service 105. Labeling tools 160 automatically determine possible labels for the example NL sentences and allow the user to create new domains, intent actions, intent objects and slots. For example, the tools may be used by a developer to add their own tags for intent and slots or select automatically determined tags. The labeling tools 160 may use domain detector 122, intent action detector 123, intent object detector 124 and slot tagging component 125.
[0022] Domain detector 122 identifies the domains from different NL sentences. For example, a developer may provide example NL sentences that they would like coverage for in the CU service. Domain detector 122 may identify a single domain or multiple domains from the examples. For example, domain detector 122 may identify both a movie domain and a social domain from one example NL sentence and identify a movie domain from another example NL sentence. The domains that are detected from the examples may or may not already be supported by CU service 105. The results of domain detector 122 may be displayed in graphical user interface (GUI) 112.
[0023] Intent action detector 123 is configured to predict the intent action for the current example NL sentence. An intent action is the action to be performed (e.g. find, post, play, buy ....) in the example NL sentence. For example, intent action detector 123 may predict the intent action for a current NL sentence to be: a get action; a find action; a post action; a play action; and the like. The predicted intent action may be displayed to the developer in GUI 112 to determine if the predicted intent action is the desired action.
[0024] For each determined intent action, one or more intent objects are identified by intent object detector 124. An intent object is an object that relates to that determined intent action. The intent object is the object of the determined intent action (e.g. movie, picture, item...). The results of intent object detector 124 may be displayed in graphical user interface (GUI) 112. According to an embodiment, the intent (i.e. the combination of the intent action and intent object) is determined from the current example NL sentence.
[0025] Slot tagging is performed by slot tagging component 125 using the determined domains, intent actions, and intent objects. Generally, slot tagging identifies what slots are associated with the words of a NL sentence. The example NL sentences may be automatically tagged using the predictions and then corrected by the developer when determined. For example, a developer may use GUI 112 to change the tagging. The results of slot tagging component 125 may be displayed in graphical user interface (GUI) 112.
[0026] Training tools 170 include different tools that can be used to update the models of CU service 105. For example, a developer may select a training tool to update one or more of the models with additional training data.
[0027] Validation tools 180 may be used by a developer to determine the accuracy of the updated models. For example, the validation tools 180 may be used to compare the results that are obtained using the models with expected results. The validation tools 180 may also be used by the developer to see if individual examples are processed correctly. The results may be corrected (e.g., by changing labels) when the validation tools 180 indicate that the results are not correct.
[0028] In order to facilitate communication with the development manager 26, one or more callback routines, may be implemented. According to an embodiment, application program 110 is a multimodal application that is configured to receive speech input and input from a touch-sensitive input device 115 or other input devices. For example, voice input, keyboard input (e.g., a physical keyboard and/or SIP), video based input, and the like. Application program 110 may also provide multimodal output (e.g., speech, graphics, vibrations, sounds ...). Development manager 26 may provide information to/from application 110 in response to user input (e.g., speech, gesture). For example, a user may say a phrase to identify a task to perform by application 110 (e.g., selecting a movie, buying an item, identifying a product ...). Gestures may include, but are not limited to: a pinch gesture; a stretch gesture; a select gesture (e.g., a tap action on a displayed element); a select and hold gesture (e.g., a tap and hold gesture received on a displayed element); a swiping action and/or dragging action; and the like. Gestures may also include optically captured gestures, such as: a wave gesture, a scroll gesture, a guide gesture, and the like. For example, a device, such as MICROSOFT KINECT may be used to detect gestures.
[0029] System 100 as illustrated comprises a touch screen input device 115 that detects when a touch input has been received (e.g., a finger touching or nearly teaching the touch screen). Any type of touch screen may be utilized that detects a user's touch input. More details are provided below.
[0030] FIGURE 2 shows an exemplary graphical user interface for labeling example NL sentences.
[0031] As illustrated, FIGURE 2 shows graphical user interface (GUI) 200 that includes a current NL example sentence 205, a domain section 210, an intent action 220 section, an intent object 230 section, and a slot 240 section.
[0032] According to an embodiment, the CU service includes a set of models including a domain model, one or more intent models and a slot model that are trained for one or more domains. For purposes of explanation, the following example relates to a CU service that is trained for four different domains, including a Game domain, a Movie domain, a Music domain, and a Generic Commands domain. The data that is used to train the models for the CU service is annotated. As discussed above, labeling tools can be used by a developer to assist in labeling the data used to update the models.
[0033] In the current example, a developer has submitted example NL sentences that relate to sports and possibly other domains. Generally, the example NL sentences are sentences that are illustrative of how a user would interact with the application being developed. For example, in a sports application, the domains may include information that relates to a Sports domain, a Weather domain, a Movie domain, a Generic Commands domain, and the like.
[0034] Each of the example NL sentences submitted by the developer can be processed by labeling tools. Additional NL sentences may also be automatically generated using the example NL sentences. For example, the example NL sentences may be rephrased using a sentence rephrasing tool that automatically generates an enriched list of sentences which contain different ways of expressing the same meaning as the example NL sentences.
[0035] GUI 200 shows the processing of the example NL sentence 205 "Show me Kobe Bryant jump shot pictures".
[0036] Domain section 210 shows results from running a domain detector on example NL sentence 205. The domain detector may be automatically run or manually run. For example, the developer may select domain option 212 to run the domain detector. As illustrated, the domain detector identifies the domains from the available domains in the CU service that relate to the example NL sentence 205 and a confidence score for the domain. The confidence score provides an indication to a developer as to whether or not the domain is correctly identified for the example NL sentence. According to an embodiment, the confidence score ranges between 0 and 1, where a higher score indicates that the domain is more related to the example NL sentence as compared to a lower score.
The developer can pick one of the suggested domains (e.g., by selecting the displayed box next to the domain) or add their own domain by selecting the add Domain option 214. In the current example, the developer has added a new "Sports" domain.
[0037] Intent Action section 220 shows results from running an intent action detector on example NL sentence 205. The intent action detector may be automatically run or manually run. For example, the developer may select intent action option 222 to run the intent action detector. In response to running the intent action classifier, the most likely intent actions (e.g., top N results) along with a confidence score is displayed. The developer may also select the see examples option 226 to see example NL sentences that use the displayed intent action labels that are already included in the models. The developer can compare the example NL sentence to the example sentences and decide to pick one of the suggested intent actions or the developer can choose to add his own intent action to label the example NL sentence. For example, the user may select the add intent action option 224.
[0038] Intent Object section 230 shows results from running an intent object detector on the example NL sentence 205. The intent object detector may be automatically run or manually run. For example, the developer may select intent object option 232 to run the intent object detector. In response to running the intent object classifier, the most likely intent objects (e.g., top N results) along with a confidence score are displayed. The developer may also select the see examples option 236 to view example NL sentences that use the displayed intent object labels that are already included in the model. The developer can compare the example NL sentence to the example sentences and decide to pick one of the suggested intent objects or the developer can choose to add his own intent object to label the example NL sentence. For example, the user may select the add intent object option 234.
[0039] Slot section 240 shows results from slot tagging the entities in example NL sentence 205. The slot tagging may be automatically run or manually run. For example, the developer may select slot tagging option 242 to run the slot tagging. In response to running the slot tagging, different detected slots (e.g., the top N results) along with a confidence score are displayed. The developer may also select the see examples 246 option to view similar slots that are already included in the model. The developer can either pick what is suggested or choose to highlight the sequences in the sentence and assign a new slot name by selecting the add new slot option 244. In the current example, the developer has created a new "Athlete" slot.
[0040] After performing the above steps for one or more of the sentences the platform automatically updates the models to make better suggestions to the developer for the next set of example NL sentences.
[0041] The proposed process biases the developers to label their data similarly to the already existing data.
[0042] FIGURES 3-5 illustrate a process for using tools to build a conversational understanding system. When reading the discussion of the routines presented herein, it should be appreciated that the logical operations of various embodiments are implemented (1) as a sequence of computer implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system. The implementation is a matter of choice dependent on the performance requirements of the computing system implementing the invention.
Accordingly, the logical operations illustrated and making up the embodiments described herein are referred to variously as operations, structural devices, acts or modules. These operations, structural devices, acts and modules may be implemented in software, in firmware, in special purpose digital logic, and any combination thereof.
[0043] FIGURE 3 shows a process for using tools to create an application to interact with a conversational understanding service.
[0044] After a start operation, the process 300 moves to operation 310, where the tools to develop and enable a CU application are displayed. Tools are provided to allow developers to build applications to interact with Conversational Understanding (CU) systems and services. The tools include a variety of different tools, such as, but not limited to: selecting API tools, labeling tools, training tools, validation tools, and the like. The tools may be used to select functionality from existing domains, extend one or more domains, as well as to create new domains.
[0045] Transitioning to operation 320, the tools are used to determine what domains to use in the application as well as the corresponding APIs for the application. For example, a domain detector may be used to identify the existing domains in the CU service that relate to the application being developed. A user may also select one or more existing APIs that are associated with one or more domains.
[0046] Moving to decision operation 330, a determination is made as to whether there is an update to a domain or whether a domain is to be added to the CU system. When there is not either an update to a domain or a domain is not to be added, the process flows to
operation 350. When there is an update to a domain or a domain is to be added, the process flows to operation 340.
[0047] At operation 340, the tools are used to update and validate the models. For example, labeling tools, training tools and validation tools may be used by the developer to update the CU service to include coverage for the application that is being developed.
[0048] Moving to operation 350, the models in the CU system are used by the application. The models may be used by one or more applications.
[0049] The process then flows to an end operation and returns to processing other actions.
[0050] FIGURE 4 shows a process for automatically detecting domains, actions, and objects from example natural language sentences to build customized models by mixing and matching domain models, intent models, or slot models or combining the underlying data to train new models.
[0051] After a start operation, the process 400 moves to operation 410, where example NL sentences are received. The example NL sentences may be received in different forms. For example, the examples may be in a form of sentences or utterances. For example, an example NL sentence may be "find the most recent torn cruise movie". Another example may be "post this link on social network site X".
[0052] Flowing to operation 420, the domains associated with the example NL sentences are detected. Generally, a domain is an area that is associated with a set of actions (e.g. movie domain, music domain, book domain, game domain, flight domain...). Zero or more domains may be detected depending on the domains that are already included in the domain model of the CU service. For example, a domain model may initially include one domain (e.g. movies) that is then extended to include another domain (e.g. social). More domains may be added or removed from the domain model. In the examples provided above, two different domains may be detected (e.g. movie and social).
[0053] Moving to operation 430, the output of the domain detection is used to determine the intent action(s) that are associated with each of the detected domains. One or more intent actions may be detected. An intent action is an action to be performed (e.g. find, post, play, buy ....). In the examples provided above, the intent actions detected include "find" and "post". The detected domains may or may not be used to assist in detecting any intent actions. The intent action domain may tag different intent actions according to the domain(s) the intent action is associated with. For example, the intent action "find" may
be associated with many different domains (e.g. movie, games, books, flight, ...) whereas the intent action "post" may be associated with a single domain (e.g. social).
[0054] Transitioning to operation 440, the intent object(s) are detected. For each determined intent action, one or more intent objects are identified. An intent object is an object that relates to that determined intent action. The intent object is the object of the determined intent action (e.g. movie, picture, item...). In the examples provided above, the intent objects detected include "movie" and "picture".
[0055] Flowing to operation 450, slot tagging is performed. One or more slot models may be used. In the examples provided above, the slots for the movie slot model include a ReleaseDate slot that is set to "most recent", a MovieStar slot that is set to "torn cruise", a MovieType slot that is set to "movie", and an ItemType slot that is set to "picture". The slots for the social media slot model include and a SocialMedia slot that is set to "X". Other domains may include other types of slots. For example, a travel domain may comprise slots for departure location, departure time, arrival time, arrival destination, travel method, constraints (e.g., lowest cost, no layovers, etc.). A dining domain may comprise slots for cuisine type, time, party size, reservation needed, and relative location (e.g., in walking distance, near a transit station, etc.). The developer may add one or more slots to a slot model. For example, the slot model for the travel domain may not include a slot for the travel method. Using the provided examples of tagging the utterance, the developer may create a new slot.
[0056] Moving to operation 460, models for the CU system are updated or customized. According to an embodiment, new models may be trained.
[0057] The process then moves to an end operation and returns to processing other actions.
[0058] FIGURE 5 shows a process for adding or updating a domain that is associated with a conversational understanding system.
[0059] After a start operation, the process 500 moves to operation 510, where a domain to update or add to a CU service is determined. One or more models may be updated or created. According to an embodiment, four models are updated including a domain model, an intent action model, an intent object model and a slot model. According to another embodiment, two new models (intent and slot models) are created when a domain is added.
[0060] Flowing to operation 520, the domain model is updated with the new domain to add. For purposes of explanation, assume the understanding system currently supports four
different domains (movies, music, games and generic commands) and that a sport domain is to be added. Instead of adding two new models to the understanding system, the existing domain model is updated to detect the new Sports domain when language relating to the Sports domain is located within a NL sentence.
[0061] Transitioning to operation 530, the intent action model is updated to support any new intent actions that are not already included in the intent action model. Many intent actions associated with the new domain may already be supported by the intent action model before being updated. For example, "get" and "find" intent actions that are associated with the sports domain may already be supported by the intent action model. Zero or more intent actions may be added to the intent action model (e.g. "schedule" ...).
[0062] Moving to operation 540, the intent object model is updated to support any new intent objects that are not already included in the intent object model. Many intent objects associated with the new domain may already be supported by the intent object model before being updated. For example, the intent objects already supported may include "game", "photos", "person information". Zero or more intent objects may be added to the intent object model (e.g. "news" ...).
[0063] Flowing to operation 550, the slot model is updated to support the new domain. According to an embodiment, a single slot model is used to support the domains. The slots may be associated with one or more different domains, actions and intents.
[0064] The process then moves to an end operation and returns to processing other actions.
[0065] FIGURE 6 shows an example table of using existing domains to add a new domain to a conversational understanding system by re-using intents (or intent actions and/or objects) from existing domains.
[0066] For purposes of explanation, and not intended to be limiting, the models in the example CU service are trained using four different domains including a Movie domain, a Music domain, a Games domain and a Generic Commands domain. More or less domains may be used to train the models.
[0067] In the current example, a developer wants to add a new Sports domain to the CU service. According to an embodiment, the developer supplies example NL sentences. For each example NL sentence, the tools predict an intent action and an intent object.
[0068] Table 600 includes an example NL sentence column, a predicted intent action column, a true intent action column, a predicted intent object column, a true intent object column, and a predicted intent column. Table 600 shows four example NL sentences.
[0069] As can be seen by referring to table 600, the predicted intent actions are accurately predicted even though the sports domain is not part of the current CU service. In the current example, the predicted intent actions are the same as the true intent actions. The predicted intent objects are not as accurately predicted as compared to the intent actions, but they are reasonable.
[0070] In the first two NL sentences in table 600, the "game" intent object label from the Games domain is predicted as each of the first two NL sentences is related to a game or match.
[0071] The third NL sentence example shares the intent action and intent object with existing domains and is correctly predicted.
[0072] The fourth NL sentence example detected the right context of retrieving information using the "get person info" although the true intent was to fetch "get news".
[0073] As the number of covered domains in the CU service increases beyond the four in the current example, the predictions would become more accurate due to better coverage. From experimental results it was found that the automatically determined predictions are accurate over 90% of the time.
[0074] FIGURE 7 illustrates a conversational understanding system interacting with an application using functionality created by a developer using provided tools.
[0075] As illustrated, system 700 includes input manager 710, language understanding component 720, dialog engine 730, response generator 740, and application 770.
[0076] Application 770 is an application that is configured to interact with CU service 705 and was developed using the tools as described herein. Application 770 may include a natural user interface (NUI) or some other interface to interact with CU service 705. For example, a combination of a natural language dialog and other non-verbal modalities of expressing intent (e.g., gestures, touch, gaze, images, videos, spoken prosody, etc.) may be used to interact with service 705. As illustrated, CU service 705 receives speech utterances from application 770 and is configured to have a dialog with a user.
[0077] Input manager 710 is configured to receive input (the user dialog act) from application 770. The user dialog act may be different types of user input. For example, the user dialog act may be speech input (e.g., an utterance), touch input, gesture input, text input, as well as other types of input.
[0078] Input manager 710 may include different components, such as an Automatic Speech Recognizer (ASR), a gesture recognizer, a handwriting recognizer, and the like. When the user dialog act is speech, the speech is recognized by input manager 710 using
ASR. Input manager 710 outputs text that is delivered to language understanding component 720.
[0079] Language understanding component 720 is configured to receive and analyze the text. Generally, language understanding component 720 associates a meaning to the words of the text. For example, language understanding component 720 may tag the text, perform a syntactic analysis of the text, and the like. The language understanding component 720 is traditionally a rules based component that converts natural language sentences into semantic representations.
[0080] Dialog engine 730 manages the dialog by determining a machine action in response to the user dialog act. Dialog engine 730 computes possible dialog states using dialog state computation component 732. Dialog manager 734 determines the machine action or machine actions. The dialog state information that is used by dialog manager 734 includes information for the current turn in the dialog as well as information for one or more past turns in the dialog. Dialog engine 730 provides the determined machine action to response generator 740.
[0081 ] Response generator 740 determines what type of response to provide the user. For example, response generator 740 may determine to provide a spoken response to the user or a visual response to the user. For example, a Text-to-Speech ("TTS") component may output the response as synthesized speech when determined. Response generator 740 provides the response to the input to application 770.
[0082] FIGURE 8 illustrates an exemplary online system that provides tools for developing a conversational understanding application.
[0083] As illustrated, system 1000 includes service 1010, data store 1045, tools 1046, touch screen input device 1050 (e.g., a slate), smart phone 1030 and display device 1080.
[0084] As illustrated, service 1010 is a cloud based and/or enterprise based service that may be configured to provide services, such as dialog services as described herein. The service may be interacted with using different types of input and output. For example, a user may use speech input, touch input, hardware based input, and the like. Functionality of one or more of the services provided by service 1010 may also be configured as a client server based application.
[0085] As illustrated, service 1010 is a multi-tenant service that provides resources 1015 and services to any number of tenants (e.g., Tenants 1-N). Multi-tenant service 1010 is a cloud based service that provides resources 1015 to tenants subscribed to the service and maintains each tenant's data separately and protected from other tenant data.
[0086] System 1000 as illustrated comprises a touch screen input device 1050 (e.g., a slate device) and smart phone 1030 that detects when a touch input has been received (e.g., a finger touching or nearly touching the touch screen). Any type of touch screen may be utilized that detects a user's touch input. For example, the touch screen may include one or more layers of capacitive material that detects the touch input. Other sensors may be used in addition to or in place of the capacitive material. For example, Infrared (IR) sensors may be used. According to an embodiment, the touch screen is configured to detect objects that in contact with or above a touchable surface. Although the term "above" is used in this description, it should be understood that the orientation of the touch panel system is irrelevant. The term "above" is intended to be applicable to all such orientations. The touch screen may be configured to determine locations of where touch input is received (e.g., a starting point, intermediate points and an ending point). Actual contact between the touchable surface and the object may be detected by any suitable means, including, for example, by a vibration sensor or microphone coupled to the touch panel. A non-exhaustive list of examples for sensors to detect contact includes pressure-based mechanisms, micro-machined accelerometers, piezoelectric devices, capacitive sensors, resistive sensors, inductive sensors, laser vibrometers, and LED vibrometers.
[0087] According to an embodiment, smart phone 1030, touch screen input device 1050, and device 1080 are configured with multimodal input and output and each include an application (1031, 1051, 1081) that interact with service 1010 and were developed using tools 1046.
[0088] As illustrated, touch screen input device 1050, smart phone 1030, and display device 1080 shows exemplary displays 1052, 1032, and 1082 showing the use of an application. Data may be stored on a device (e.g., smart phone 1030, touch screen input device 1050 and/or at some other location (e.g., network data store 1045). Data store 1045, or some other store, may be used to store models, as well as other data. The applications used by the devices may be client based applications, server based applications, cloud based applications or some combination. According to an embodiment, display device 1080 is a device such as a MICROSOFT XBOX coupled to a display.
[0089] Development manager 26 is configured to perform operations relating to processes as described herein. Development manager 26 is configured to access tools 1046 that are used by a developer to create an application to interact with service 1010. While manager 26 is shown within service 1010, the functionality of the manager may be
included in other locations (e.g., on smart phone 1030 and/or touch screen input device 1050 and/or device 1080).
[0090] The embodiments and functionalities described herein may operate via a multitude of computing systems including, without limitation, desktop computer systems, wired and wireless computing systems, mobile computing systems (e.g., mobile telephones, netbooks, tablet or slate type computers, notebook computers, and laptop computers), hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, and mainframe computers.
[0091] In addition, the embodiments and functionalities described herein may operate over distributed systems (e.g., cloud-based computing systems), where application functionality, memory, data storage and retrieval and various processing functions may be operated remotely from each other over a distributed computing network, such as the Internet or an intranet. User interfaces and information of various types may be displayed via on-board computing device displays or via remote display units associated with one or more computing devices. For example user interfaces and information of various types may be displayed and interacted with on a wall surface onto which user interfaces and information of various types are projected. Interaction with the multitude of computing systems with which embodiments of the invention may be practiced include, keystroke entry, touch screen entry, voice or other audio entry, gesture entry where an associated computing device is equipped with detection (e.g., camera) functionality for capturing and interpreting user gestures for controlling the functionality of the computing device, and the like.
[0092] FIGURES 9-11 and the associated descriptions provide a discussion of a variety of operating environments in which embodiments of the invention may be practiced.
However, the devices and systems illustrated and discussed with respect to FIGURES 9-11 are for purposes of example and illustration and are not limiting of a vast number of computing device configurations that may be utilized for practicing embodiments of the invention, described herein.
[0093] FIGURE 9 is a block diagram illustrating physical components (i.e., hardware) of a computing device 1100 with which embodiments of the invention may be practiced. The computing device components described below may be suitable for the computing devices described above. In a basic configuration, the computing device 1100 may include at least one processing unit 1102 and a system memory 1104. Depending on the configuration and type of computing device, the system memory 1104 may comprise, but is not limited to,
volatile storage (e.g., random access memory), non-volatile storage (e.g., read-only memory), flash memory, or any combination of such memories. The system memory 1104 may include an operating system 1105 and one or more program modules 1106 suitable for running software applications 1120 such as the development manager 26. The operating system 1105, for example, may be suitable for controlling the operation of the computing device 1100. Furthermore, embodiments of the invention may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system. This basic
configuration is illustrated in FIGURE 9 by those components within a dashed line 1108. The computing device 1100 may have additional features or functionality. For example, the computing device 1100 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated in FIGURE 9 by a removable storage device 1109 and a non-removable storage device 1110.
[0094] As stated above, a number of program modules and data files may be stored in the system memory 1104. While executing on the processing unit 1102, the program modules 1106 (e.g., the development manager 26) may perform processes including, but not limited to, one or more of the stages of the methods and processes illustrated in the figures. Other program modules that may be used in accordance with embodiments of the present invention may include electronic mail and contacts applications, word processing applications, spreadsheet applications, database applications, slide presentation applications, drawing or computer-aided application programs, etc.
[0095] Furthermore, embodiments of the invention may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. For example, embodiments of the invention may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in FIGURE 9 may be integrated onto a single integrated circuit. Such an SOC device may include one or more processing units, graphics units, communications units, system virtualization units and various application functionality all of which are integrated (or "burned") onto the chip substrate as a single integrated circuit. When operating via an SOC, the functionality, described herein, with respect to the development manager 26 may be operated via application-specific logic integrated with other components of the computing device 1100 on the single integrated circuit (chip). Embodiments of the
invention may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies. In addition, embodiments of the invention may be practiced within a general purpose computer or in any other circuits or systems.
[0096] The computing device 1100 may also have one or more input device(s) 1112 such as a keyboard, a mouse, a pen, a sound input device, a touch input device, etc. The output device(s) 1114 such as a display, speakers, a printer, etc. may also be included. The aforementioned devices are examples and others may be used. The computing device 1100 may include one or more communication connections 1116 allowing communications with other computing devices 1118. Examples of suitable communication connections 1116 include, but are not limited to, RF transmitter, receiver, and/or transceiver circuitry;
universal serial bus (USB), parallel, and/or serial ports.
[0097] The term computer readable media as used herein may include computer storage media. Computer storage media may include volatile and nonvolatile, removable and nonremovable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules. The system memory 1104, the removable storage device 1109, and the non-removable storage device 1110 are all computer storage media examples (i.e., memory storage.) Computer storage media may include RAM, ROM, electrically erasable read-only memory (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 article of manufacture which can be used to store information and which can be accessed by the computing device 1100. Any such computer storage media may be part of the computing device 1100. Computer storage media does not include a carrier wave or other propagated or modulated data signal.
[0098] Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term "modulated data signal" may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
[0099] FIGURES 1 OA and 1 OB illustrate a mobile computing device 1200, for example, a mobile telephone, a smart phone, a tablet personal computer, a laptop computer, and the like, with which embodiments of the invention may be practiced. With reference to FIGURE 10A, one embodiment of a mobile computing device 1200 for implementing the embodiments is illustrated. In a basic configuration, the mobile computing device 1200 is a handheld computer having both input elements and output elements. The mobile computing device 1200 typically includes a display 1205 and one or more input buttons 1210 that allow the user to enter information into the mobile computing device 1200. The display 1205 of the mobile computing device 1200 may also function as an input device (e.g., a touch screen display). If included, an optional side input element 1215 allows further user input. The side input element 1215 may be a rotary switch, a button, or any other type of manual input element. In alternative embodiments, mobile computing device 1200 may incorporate more or less input elements. For example, the display 1205 may not be a touch screen in some embodiments. In yet another alternative embodiment, the mobile computing device 1200 is a portable phone system, such as a cellular phone. The mobile computing device 1200 may also include an optional keypad 1235. Optional keypad 1235 may be a physical keypad or a "soft" keypad generated on the touch screen display. In various embodiments, the output elements include the display 1205 for showing a graphical user interface (GUI), a visual indicator 1220 (e.g., a light emitting diode), and or an audio transducer 1225 (e.g., a speaker). In some embodiments, the mobile computing device 1200 incorporates a vibration transducer for providing the user with tactile feedback. In yet another embodiment, the mobile computing device 1200 incorporates input and/or output ports, such as an audio input (e.g., a microphone jack), an audio output (e.g., a headphone jack), and a video output (e.g., a HDMI port) for sending signals to or receiving signals from an external device.
[00100] FIGURE 10B is a block diagram illustrating the architecture of one embodiment of a mobile computing device. That is, the mobile computing device 1200 can incorporate a system 1202 (i.e., an architecture) to implement some embodiments. In one embodiment, the system 1202 is implemented as a "smart phone" capable of running one or more applications (e.g., browser, e-mail, calendaring, contact managers, messaging clients, games, and media clients, players). In some embodiments, the system 1202 is integrated as a computing device, such as an integrated personal digital assistant (PDA) and wireless phone.
[00101] One or more application programs 1266 may be loaded into the memory 1262 and run on or in association with the operating system 1264. Examples of the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth. The system 1202 also includes a non-volatile storage area 1268 within the memory 1262. The non-volatile storage area 1268 may be used to store persistent information that should not be lost if the system 1202 is powered down. The application programs 1266 may use and store information in the non-volatile storage area 1268, such as e-mail or other messages used by an e-mail application, and the like. A synchronization application (not shown) also resides on the system 1202 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in the non-volatile storage area 1268 synchronized with corresponding information stored at the host computer. As should be appreciated, other applications may be loaded into the memory 1262 and run on the mobile computing device 1200, including the development manager 26 as described herein.
[00102] The system 1202 has a power supply 1270, which may be implemented as one or more batteries. The power supply 1270 might further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries.
[00103] The system 1202 may also include a radio 1272 that performs the function of transmitting and receiving radio frequency communications. The radio 1272 facilitates wireless connectivity between the system 1202 and the "outside world", via a
communications carrier or service provider. Transmissions to and from the radio 1272 are conducted under control of the operating system 1264. In other words, communications received by the radio 1272 may be disseminated to the application programs 1266 via the operating system 1264, and vice versa.
[00104] The visual indicator 1220 may be used to provide visual notifications, and/or an audio interface 1274 may be used for producing audible notifications via the audio transducer 1225. In the illustrated embodiment, the visual indicator 1220 is a light emitting diode (LED) and the audio transducer 1225 is a speaker. These devices may be directly coupled to the power supply 1270 so that when activated, they remain on for a duration dictated by the notification mechanism even though the processor 1260 and other components might shut down for conserving battery power. The LED may be programmed
to remain on indefinitely until the user takes action to indicate the powered-on status of the device. The audio interface 1274 is used to provide audible signals to and receive audible signals from the user. For example, in addition to being coupled to the audio transducer 1225, the audio interface 1274 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation. In accordance with embodiments of the present invention, the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below. The system 1202 may further include a video interface 1276 that enables an operation of an on-board camera to record still images, video stream, and the like.
[00105] A mobile computing device 1200 implementing the system 1202 may have additional features or functionality. For example, the mobile computing device 1200 may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape. Such additional storage is illustrated in FIGURE 10B by the non-volatile storage area 1268. Mobile computing device 1200 may also include peripheral device port 1230.
[00106] Data/information generated or captured by the mobile computing device 1200 and stored via the system 1202 may be stored locally on the mobile computing device 1200, as described above, or the data may be stored on any number of storage media that may be accessed by the device via the radio 1272 or via a wired connection between the mobile computing device 1200 and a separate computing device associated with the mobile computing device 1200, for example, a server computer in a distributed computing network, such as the Internet. As should be appreciated such data information may be accessed via the mobile computing device 1200 via the radio 1272 or via a distributed computing network. Similarly, such data/information may be readily transferred between computing devices for storage and use according to well-known data information transfer and storage means, including electronic mail and collaborative data/information sharing systems.
[00107] FIGURE 11 illustrates an embodiment of an architecture of an exemplary system, as described above. Content developed, interacted with, or edited in association with the development manager 26 may be stored in different communication channels or other storage types. For example, various documents may be stored using a directory service 1322, a web portal 1324, a mailbox service 1326, an instant messaging store 1328, or a social networking site 1330. The development manager 26 may use any of these types of systems or the like for enabling data utilization, as described herein. A server 1320 may
provide the development manager 26 to clients. As one example, the server 1320 may be a web server providing the development manager 26 over the web. The server 1320 may provide the development manager 26 over the web to clients through a network 1315. By way of example, the client computing device may be implemented as the computing device 1100 and embodied in a personal computer, a tablet computing device 1310 and/or a mobile computing device 1200 (e.g., a smart phone). Any of these embodiments of the client computing device 1100, 1310, and 1200 may obtain content from the store 1316.
[00108] Embodiments of the present invention, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to embodiments of the invention. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the
functionality/acts involved.
[00109] The description and illustration of one or more embodiments provided in this application are not intended to limit or restrict the scope of the invention as claimed in any way. The embodiments, examples, and details provided in this application are considered sufficient to convey possession and enable others to make and use the best mode of claimed invention. The claimed invention should not be construed as being limited to any embodiment, example, or detail provided in this application. Regardless of whether shown and described in combination or separately, the various features (both structural and methodological) are intended to be selectively included or omitted to produce an embodiment with a particular set of features. Having been provided with the description and illustration of the present application, one skilled in the art may envision variations, modifications, and alternate embodiments falling within the spirit of the broader aspects of the general inventive concept embodied in this application that do not depart from the broader scope of the claimed invention.
Claims
1. A method for enabling an application for Conversational Understanding (CU) using assets in a CU service, comprising:
determining a domain for the application to use;
receiving a selection of Application Programming Interfaces (APIs) that are associated with the domain to use in the application;
automatically updating models for the CU service based on the selection of the APIs and the determined domain; and
making the models available to the CU service.
2. The method of Claim 1 , wherein determining the domain comprises receiving examples of natural language sentences used to interact with the application and automatically determining the domain using the examples.
3. The method of Claim 1, further comprising receiving examples of Natural Language sentences used to interact with the application and automatically rephrasing the examples of the NL sentences to generate additional sentences that contain different ways of expressing a meaning of each of the NL sentences.
4. The method of Claim 1, wherein determining the domain comprises applying a domain detector to examples to determine domains that currently exist in the CU service and receiving a selection of one or more of the domains.
5. A computer-readable storage medium storing computer-executable instructions for enabling an application for Conversational Understanding (CU) using assets in a CU service, comprising:
displaying a Graphical User Interface (GUI) that includes a display of tools used to enable the application;
receiving examples of Natural Language (NL) sentences used to interact with the application;
detecting a domain, an intent action, and an intent object;
displaying the detected domain, the intent action and the intent object in the
GUI;
receiving input from the GUI to label the examples; and
automatically updating models for the CU service based on the received input.
6. The computer-readable storage medium of Claim 5, further comprising automatically rephrasing the examples of the NL sentences to generate additional sentences that contain different ways of expressing a meaning of the NL sentences.
7. The computer-readable medium of Claim 5, wherein detecting the domain comprises applying a domain detector to the examples.
8. A system for using tools to enable an application for Conversational Understanding (CU) using assets from a CU service, comprising:
a processor and memory;
an operating environment executing using the processor; and a development manager that is configured to perform actions comprising: displaying a Graphical User Interface (GUI) that includes a display of tools used to enable the application;
detecting a domain, an intent action, and an intent object from examples of
Natural Language (NL) sentences used to interact with the application;
performing slot tagging on the examples;
displaying the detected domain, the intent action, the intent object and the slot tagging in the GUI;
receiving input from the GUI to label the examples; and
automatically updating models for the CU service based on the received input.
9. The system of Claim 8, wherein detecting the domain comprises applying a domain detector to the examples to determine domains that currently exist in the CU service and displaying a confidence for each of the domains and receiving a selection of one of the domains or receiving a selection to add a new domain.
10. The system of Claim 8, wherein detecting the intent action comprises detecting intent actions from the examples and displaying a con idence for each of the detected intent actions and receiving a selection of one of the intent actions or receiving a selection to add a new intent action.
Priority Applications (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP14736143.0A EP3011472A2 (en) | 2013-06-21 | 2014-06-05 | Building conversational understanding systems |
CN201480035400.4A CN105474170B (en) | 2013-06-21 | 2014-06-05 | It constructs session and understands system |
KR1020157035936A KR102303483B1 (en) | 2013-06-21 | 2014-06-05 | Building conversational understanding systems |
CN201910428922.5A CN110263327B (en) | 2013-06-21 | 2014-06-05 | Building session understanding system |
KR1020217029117A KR102406236B1 (en) | 2013-06-21 | 2014-06-05 | Building conversational understanding systems |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/923,969 US9311298B2 (en) | 2013-06-21 | 2013-06-21 | Building conversational understanding systems using a toolset |
US13/923,969 | 2013-06-21 |
Publications (2)
Publication Number | Publication Date |
---|---|
WO2014204659A2 true WO2014204659A2 (en) | 2014-12-24 |
WO2014204659A3 WO2014204659A3 (en) | 2015-07-23 |
Family
ID=51134330
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2014/041023 WO2014204659A2 (en) | 2013-06-21 | 2014-06-05 | Building conversational understanding systems using a toolset |
Country Status (5)
Country | Link |
---|---|
US (3) | US9311298B2 (en) |
EP (1) | EP3011472A2 (en) |
KR (2) | KR102303483B1 (en) |
CN (2) | CN110263327B (en) |
WO (1) | WO2014204659A2 (en) |
Cited By (136)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016122902A3 (en) * | 2015-01-30 | 2016-10-27 | Microsoft Technology Licensing, Llc | Updating language understanding classifier models for a digital personal assistant based on crowd-sourcing |
WO2017127321A1 (en) * | 2016-01-23 | 2017-07-27 | Microsoft Technology Licensing, Llc | Tool for facilitating the development of new language understanding scenarios |
US9865248B2 (en) | 2008-04-05 | 2018-01-09 | Apple Inc. | Intelligent text-to-speech conversion |
US9966060B2 (en) | 2013-06-07 | 2018-05-08 | Apple Inc. | System and method for user-specified pronunciation of words for speech synthesis and recognition |
US9971774B2 (en) | 2012-09-19 | 2018-05-15 | Apple Inc. | Voice-based media searching |
US9986419B2 (en) | 2014-09-30 | 2018-05-29 | Apple Inc. | Social reminders |
US10043516B2 (en) | 2016-09-23 | 2018-08-07 | Apple Inc. | Intelligent automated assistant |
US10049675B2 (en) | 2010-02-25 | 2018-08-14 | Apple Inc. | User profiling for voice input processing |
US10067938B2 (en) | 2016-06-10 | 2018-09-04 | Apple Inc. | Multilingual word prediction |
US10079014B2 (en) | 2012-06-08 | 2018-09-18 | Apple Inc. | Name recognition system |
US10083690B2 (en) | 2014-05-30 | 2018-09-25 | Apple Inc. | Better resolution when referencing to concepts |
US10108612B2 (en) | 2008-07-31 | 2018-10-23 | Apple Inc. | Mobile device having human language translation capability with positional feedback |
US10249300B2 (en) | 2016-06-06 | 2019-04-02 | Apple Inc. | Intelligent list reading |
US10269345B2 (en) | 2016-06-11 | 2019-04-23 | Apple Inc. | Intelligent task discovery |
US10297253B2 (en) | 2016-06-11 | 2019-05-21 | Apple Inc. | Application integration with a digital assistant |
US10303715B2 (en) | 2017-05-16 | 2019-05-28 | Apple Inc. | Intelligent automated assistant for media exploration |
US10311144B2 (en) | 2017-05-16 | 2019-06-04 | Apple Inc. | Emoji word sense disambiguation |
US10311871B2 (en) | 2015-03-08 | 2019-06-04 | Apple Inc. | Competing devices responding to voice triggers |
US10318871B2 (en) | 2005-09-08 | 2019-06-11 | Apple Inc. | Method and apparatus for building an intelligent automated assistant |
US10332518B2 (en) | 2017-05-09 | 2019-06-25 | Apple Inc. | User interface for correcting recognition errors |
US10354652B2 (en) | 2015-12-02 | 2019-07-16 | Apple Inc. | Applying neural network language models to weighted finite state transducers for automatic speech recognition |
US10356243B2 (en) | 2015-06-05 | 2019-07-16 | Apple Inc. | Virtual assistant aided communication with 3rd party service in a communication session |
US10354011B2 (en) | 2016-06-09 | 2019-07-16 | Apple Inc. | Intelligent automated assistant in a home environment |
US10381016B2 (en) | 2008-01-03 | 2019-08-13 | Apple Inc. | Methods and apparatus for altering audio output signals |
US10395654B2 (en) | 2017-05-11 | 2019-08-27 | Apple Inc. | Text normalization based on a data-driven learning network |
US10403283B1 (en) | 2018-06-01 | 2019-09-03 | Apple Inc. | Voice interaction at a primary device to access call functionality of a companion device |
US10403278B2 (en) | 2017-05-16 | 2019-09-03 | Apple Inc. | Methods and systems for phonetic matching in digital assistant services |
US10410637B2 (en) | 2017-05-12 | 2019-09-10 | Apple Inc. | User-specific acoustic models |
US10417344B2 (en) | 2014-05-30 | 2019-09-17 | Apple Inc. | Exemplar-based natural language processing |
US10417405B2 (en) | 2011-03-21 | 2019-09-17 | Apple Inc. | Device access using voice authentication |
US10417266B2 (en) | 2017-05-09 | 2019-09-17 | Apple Inc. | Context-aware ranking of intelligent response suggestions |
US10431204B2 (en) | 2014-09-11 | 2019-10-01 | Apple Inc. | Method and apparatus for discovering trending terms in speech requests |
US10438595B2 (en) | 2014-09-30 | 2019-10-08 | Apple Inc. | Speaker identification and unsupervised speaker adaptation techniques |
US10445429B2 (en) | 2017-09-21 | 2019-10-15 | Apple Inc. | Natural language understanding using vocabularies with compressed serialized tries |
US10453443B2 (en) | 2014-09-30 | 2019-10-22 | Apple Inc. | Providing an indication of the suitability of speech recognition |
US10474753B2 (en) | 2016-09-07 | 2019-11-12 | Apple Inc. | Language identification using recurrent neural networks |
US10482874B2 (en) | 2017-05-15 | 2019-11-19 | Apple Inc. | Hierarchical belief states for digital assistants |
US10496705B1 (en) | 2018-06-03 | 2019-12-03 | Apple Inc. | Accelerated task performance |
US10497365B2 (en) | 2014-05-30 | 2019-12-03 | Apple Inc. | Multi-command single utterance input method |
US10529332B2 (en) | 2015-03-08 | 2020-01-07 | Apple Inc. | Virtual assistant activation |
US10567477B2 (en) | 2015-03-08 | 2020-02-18 | Apple Inc. | Virtual assistant continuity |
US10592604B2 (en) | 2018-03-12 | 2020-03-17 | Apple Inc. | Inverse text normalization for automatic speech recognition |
US10593346B2 (en) | 2016-12-22 | 2020-03-17 | Apple Inc. | Rank-reduced token representation for automatic speech recognition |
US10636424B2 (en) | 2017-11-30 | 2020-04-28 | Apple Inc. | Multi-turn canned dialog |
US10643611B2 (en) | 2008-10-02 | 2020-05-05 | Apple Inc. | Electronic devices with voice command and contextual data processing capabilities |
US10657328B2 (en) | 2017-06-02 | 2020-05-19 | Apple Inc. | Multi-task recurrent neural network architecture for efficient morphology handling in neural language modeling |
US10657961B2 (en) | 2013-06-08 | 2020-05-19 | Apple Inc. | Interpreting and acting upon commands that involve sharing information with remote devices |
US10684703B2 (en) | 2018-06-01 | 2020-06-16 | Apple Inc. | Attention aware virtual assistant dismissal |
US10699717B2 (en) | 2014-05-30 | 2020-06-30 | Apple Inc. | Intelligent assistant for home automation |
US10706841B2 (en) | 2010-01-18 | 2020-07-07 | Apple Inc. | Task flow identification based on user intent |
US10714117B2 (en) | 2013-02-07 | 2020-07-14 | Apple Inc. | Voice trigger for a digital assistant |
US10726832B2 (en) | 2017-05-11 | 2020-07-28 | Apple Inc. | Maintaining privacy of personal information |
US10733993B2 (en) | 2016-06-10 | 2020-08-04 | Apple Inc. | Intelligent digital assistant in a multi-tasking environment |
US10733375B2 (en) | 2018-01-31 | 2020-08-04 | Apple Inc. | Knowledge-based framework for improving natural language understanding |
US10733982B2 (en) | 2018-01-08 | 2020-08-04 | Apple Inc. | Multi-directional dialog |
US10741185B2 (en) | 2010-01-18 | 2020-08-11 | Apple Inc. | Intelligent automated assistant |
US10748546B2 (en) | 2017-05-16 | 2020-08-18 | Apple Inc. | Digital assistant services based on device capabilities |
US10755051B2 (en) | 2017-09-29 | 2020-08-25 | Apple Inc. | Rule-based natural language processing |
US10755703B2 (en) | 2017-05-11 | 2020-08-25 | Apple Inc. | Offline personal assistant |
US10769385B2 (en) | 2013-06-09 | 2020-09-08 | Apple Inc. | System and method for inferring user intent from speech inputs |
US10791176B2 (en) | 2017-05-12 | 2020-09-29 | Apple Inc. | Synchronization and task delegation of a digital assistant |
US10789945B2 (en) | 2017-05-12 | 2020-09-29 | Apple Inc. | Low-latency intelligent automated assistant |
US10789959B2 (en) | 2018-03-02 | 2020-09-29 | Apple Inc. | Training speaker recognition models for digital assistants |
US10795541B2 (en) | 2009-06-05 | 2020-10-06 | Apple Inc. | Intelligent organization of tasks items |
US10810274B2 (en) | 2017-05-15 | 2020-10-20 | Apple Inc. | Optimizing dialogue policy decisions for digital assistants using implicit feedback |
US10818288B2 (en) | 2018-03-26 | 2020-10-27 | Apple Inc. | Natural assistant interaction |
US10839159B2 (en) | 2018-09-28 | 2020-11-17 | Apple Inc. | Named entity normalization in a spoken dialog system |
US10892996B2 (en) | 2018-06-01 | 2021-01-12 | Apple Inc. | Variable latency device coordination |
US10904611B2 (en) | 2014-06-30 | 2021-01-26 | Apple Inc. | Intelligent automated assistant for TV user interactions |
US10909331B2 (en) | 2018-03-30 | 2021-02-02 | Apple Inc. | Implicit identification of translation payload with neural machine translation |
US10928918B2 (en) | 2018-05-07 | 2021-02-23 | Apple Inc. | Raise to speak |
US10942702B2 (en) | 2016-06-11 | 2021-03-09 | Apple Inc. | Intelligent device arbitration and control |
US10942703B2 (en) | 2015-12-23 | 2021-03-09 | Apple Inc. | Proactive assistance based on dialog communication between devices |
US10984780B2 (en) | 2018-05-21 | 2021-04-20 | Apple Inc. | Global semantic word embeddings using bi-directional recurrent neural networks |
US11010127B2 (en) | 2015-06-29 | 2021-05-18 | Apple Inc. | Virtual assistant for media playback |
US11010561B2 (en) | 2018-09-27 | 2021-05-18 | Apple Inc. | Sentiment prediction from textual data |
US11025565B2 (en) | 2015-06-07 | 2021-06-01 | Apple Inc. | Personalized prediction of responses for instant messaging |
US11023513B2 (en) | 2007-12-20 | 2021-06-01 | Apple Inc. | Method and apparatus for searching using an active ontology |
US11048473B2 (en) | 2013-06-09 | 2021-06-29 | Apple Inc. | Device, method, and graphical user interface for enabling conversation persistence across two or more instances of a digital assistant |
US11069347B2 (en) | 2016-06-08 | 2021-07-20 | Apple Inc. | Intelligent automated assistant for media exploration |
US11070949B2 (en) | 2015-05-27 | 2021-07-20 | Apple Inc. | Systems and methods for proactively identifying and surfacing relevant content on an electronic device with a touch-sensitive display |
US11069336B2 (en) | 2012-03-02 | 2021-07-20 | Apple Inc. | Systems and methods for name pronunciation |
US11080012B2 (en) | 2009-06-05 | 2021-08-03 | Apple Inc. | Interface for a virtual digital assistant |
US11120372B2 (en) | 2011-06-03 | 2021-09-14 | Apple Inc. | Performing actions associated with task items that represent tasks to perform |
US11127397B2 (en) | 2015-05-27 | 2021-09-21 | Apple Inc. | Device voice control |
US11126400B2 (en) | 2015-09-08 | 2021-09-21 | Apple Inc. | Zero latency digital assistant |
US11133008B2 (en) | 2014-05-30 | 2021-09-28 | Apple Inc. | Reducing the need for manual start/end-pointing and trigger phrases |
US11140099B2 (en) | 2019-05-21 | 2021-10-05 | Apple Inc. | Providing message response suggestions |
US11145294B2 (en) | 2018-05-07 | 2021-10-12 | Apple Inc. | Intelligent automated assistant for delivering content from user experiences |
US11170166B2 (en) | 2018-09-28 | 2021-11-09 | Apple Inc. | Neural typographical error modeling via generative adversarial networks |
US11204787B2 (en) | 2017-01-09 | 2021-12-21 | Apple Inc. | Application integration with a digital assistant |
US11217251B2 (en) | 2019-05-06 | 2022-01-04 | Apple Inc. | Spoken notifications |
US11227589B2 (en) | 2016-06-06 | 2022-01-18 | Apple Inc. | Intelligent list reading |
US11231904B2 (en) | 2015-03-06 | 2022-01-25 | Apple Inc. | Reducing response latency of intelligent automated assistants |
US11237797B2 (en) | 2019-05-31 | 2022-02-01 | Apple Inc. | User activity shortcut suggestions |
US11269678B2 (en) | 2012-05-15 | 2022-03-08 | Apple Inc. | Systems and methods for integrating third party services with a digital assistant |
US11281993B2 (en) | 2016-12-05 | 2022-03-22 | Apple Inc. | Model and ensemble compression for metric learning |
US11289073B2 (en) | 2019-05-31 | 2022-03-29 | Apple Inc. | Device text to speech |
US11301477B2 (en) | 2017-05-12 | 2022-04-12 | Apple Inc. | Feedback analysis of a digital assistant |
US11307752B2 (en) | 2019-05-06 | 2022-04-19 | Apple Inc. | User configurable task triggers |
US11314370B2 (en) | 2013-12-06 | 2022-04-26 | Apple Inc. | Method for extracting salient dialog usage from live data |
US11348573B2 (en) | 2019-03-18 | 2022-05-31 | Apple Inc. | Multimodality in digital assistant systems |
US11350253B2 (en) | 2011-06-03 | 2022-05-31 | Apple Inc. | Active transport based notifications |
US11360641B2 (en) | 2019-06-01 | 2022-06-14 | Apple Inc. | Increasing the relevance of new available information |
US11388291B2 (en) | 2013-03-14 | 2022-07-12 | Apple Inc. | System and method for processing voicemail |
US11386266B2 (en) | 2018-06-01 | 2022-07-12 | Apple Inc. | Text correction |
US11423908B2 (en) | 2019-05-06 | 2022-08-23 | Apple Inc. | Interpreting spoken requests |
US11462215B2 (en) | 2018-09-28 | 2022-10-04 | Apple Inc. | Multi-modal inputs for voice commands |
US11467802B2 (en) | 2017-05-11 | 2022-10-11 | Apple Inc. | Maintaining privacy of personal information |
US11468282B2 (en) | 2015-05-15 | 2022-10-11 | Apple Inc. | Virtual assistant in a communication session |
US11475884B2 (en) | 2019-05-06 | 2022-10-18 | Apple Inc. | Reducing digital assistant latency when a language is incorrectly determined |
US11475898B2 (en) | 2018-10-26 | 2022-10-18 | Apple Inc. | Low-latency multi-speaker speech recognition |
US11488406B2 (en) | 2019-09-25 | 2022-11-01 | Apple Inc. | Text detection using global geometry estimators |
US11496600B2 (en) | 2019-05-31 | 2022-11-08 | Apple Inc. | Remote execution of machine-learned models |
US11495218B2 (en) | 2018-06-01 | 2022-11-08 | Apple Inc. | Virtual assistant operation in multi-device environments |
US11500672B2 (en) | 2015-09-08 | 2022-11-15 | Apple Inc. | Distributed personal assistant |
US11526368B2 (en) | 2015-11-06 | 2022-12-13 | Apple Inc. | Intelligent automated assistant in a messaging environment |
US11532306B2 (en) | 2017-05-16 | 2022-12-20 | Apple Inc. | Detecting a trigger of a digital assistant |
US11638059B2 (en) | 2019-01-04 | 2023-04-25 | Apple Inc. | Content playback on multiple devices |
US11657813B2 (en) | 2019-05-31 | 2023-05-23 | Apple Inc. | Voice identification in digital assistant systems |
US11671920B2 (en) | 2007-04-03 | 2023-06-06 | Apple Inc. | Method and system for operating a multifunction portable electronic device using voice-activation |
US11696060B2 (en) | 2020-07-21 | 2023-07-04 | Apple Inc. | User identification using headphones |
US11765209B2 (en) | 2020-05-11 | 2023-09-19 | Apple Inc. | Digital assistant hardware abstraction |
US11790914B2 (en) | 2019-06-01 | 2023-10-17 | Apple Inc. | Methods and user interfaces for voice-based control of electronic devices |
US11798547B2 (en) | 2013-03-15 | 2023-10-24 | Apple Inc. | Voice activated device for use with a voice-based digital assistant |
US11809483B2 (en) | 2015-09-08 | 2023-11-07 | Apple Inc. | Intelligent automated assistant for media search and playback |
US11838734B2 (en) | 2020-07-20 | 2023-12-05 | Apple Inc. | Multi-device audio adjustment coordination |
US11853536B2 (en) | 2015-09-08 | 2023-12-26 | Apple Inc. | Intelligent automated assistant in a media environment |
US11886805B2 (en) | 2015-11-09 | 2024-01-30 | Apple Inc. | Unconventional virtual assistant interactions |
US11914848B2 (en) | 2020-05-11 | 2024-02-27 | Apple Inc. | Providing relevant data items based on context |
US12010262B2 (en) | 2013-08-06 | 2024-06-11 | Apple Inc. | Auto-activating smart responses based on activities from remote devices |
US12014118B2 (en) | 2017-05-15 | 2024-06-18 | Apple Inc. | Multi-modal interfaces having selection disambiguation and text modification capability |
US12051413B2 (en) | 2015-09-30 | 2024-07-30 | Apple Inc. | Intelligent device identification |
US12197817B2 (en) | 2016-06-11 | 2025-01-14 | Apple Inc. | Intelligent device arbitration and control |
US12223282B2 (en) | 2016-06-09 | 2025-02-11 | Apple Inc. | Intelligent automated assistant in a home environment |
US12277954B2 (en) | 2024-04-16 | 2025-04-15 | Apple Inc. | Voice trigger for a digital assistant |
Families Citing this family (130)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8181205B2 (en) | 2002-09-24 | 2012-05-15 | Russ Samuel H | PVR channel and PVR IPG information |
US8521511B2 (en) | 2007-06-18 | 2013-08-27 | International Business Machines Corporation | Information extraction in a natural language understanding system |
US9342588B2 (en) * | 2007-06-18 | 2016-05-17 | International Business Machines Corporation | Reclassification of training data to improve classifier accuracy |
US8983840B2 (en) * | 2012-06-19 | 2015-03-17 | International Business Machines Corporation | Intent discovery in audio or text-based conversation |
US9292492B2 (en) * | 2013-02-04 | 2016-03-22 | Microsoft Technology Licensing, Llc | Scaling statistical language understanding systems across domains and intents |
US10235358B2 (en) | 2013-02-21 | 2019-03-19 | Microsoft Technology Licensing, Llc | Exploiting structured content for unsupervised natural language semantic parsing |
US9728184B2 (en) | 2013-06-18 | 2017-08-08 | Microsoft Technology Licensing, Llc | Restructuring deep neural network acoustic models |
US9594542B2 (en) | 2013-06-20 | 2017-03-14 | Viv Labs, Inc. | Dynamically evolving cognitive architecture system based on training by third-party developers |
US9519461B2 (en) | 2013-06-20 | 2016-12-13 | Viv Labs, Inc. | Dynamically evolving cognitive architecture system based on third-party developers |
US9633317B2 (en) | 2013-06-20 | 2017-04-25 | Viv Labs, Inc. | Dynamically evolving cognitive architecture system based on a natural language intent interpreter |
US10474961B2 (en) | 2013-06-20 | 2019-11-12 | Viv Labs, Inc. | Dynamically evolving cognitive architecture system based on prompting for additional user input |
US9311298B2 (en) | 2013-06-21 | 2016-04-12 | Microsoft Technology Licensing, Llc | Building conversational understanding systems using a toolset |
US9589565B2 (en) | 2013-06-21 | 2017-03-07 | Microsoft Technology Licensing, Llc | Environmentally aware dialog policies and response generation |
US9997160B2 (en) * | 2013-07-01 | 2018-06-12 | Toyota Motor Engineering & Manufacturing North America, Inc. | Systems and methods for dynamic download of embedded voice components |
US10339216B2 (en) * | 2013-07-26 | 2019-07-02 | Nuance Communications, Inc. | Method and apparatus for selecting among competing models in a tool for building natural language understanding models |
US10229106B2 (en) * | 2013-07-26 | 2019-03-12 | Nuance Communications, Inc. | Initializing a workspace for building a natural language understanding system |
US9886950B2 (en) * | 2013-09-08 | 2018-02-06 | Intel Corporation | Automatic generation of domain models for virtual personal assistants |
US20150073790A1 (en) * | 2013-09-09 | 2015-03-12 | Advanced Simulation Technology, inc. ("ASTi") | Auto transcription of voice networks |
US10073840B2 (en) | 2013-12-20 | 2018-09-11 | Microsoft Technology Licensing, Llc | Unsupervised relation detection model training |
US9324321B2 (en) | 2014-03-07 | 2016-04-26 | Microsoft Technology Licensing, Llc | Low-footprint adaptation and personalization for a deep neural network |
US9529794B2 (en) | 2014-03-27 | 2016-12-27 | Microsoft Technology Licensing, Llc | Flexible schema for language model customization |
US9614724B2 (en) | 2014-04-21 | 2017-04-04 | Microsoft Technology Licensing, Llc | Session-based device configuration |
US11209897B2 (en) * | 2014-04-25 | 2021-12-28 | Lenovo (Singapore) Pte. Ltd. | Strengthening prediction confidence and command priority using natural user interface (NUI) inputs |
US9520127B2 (en) | 2014-04-29 | 2016-12-13 | Microsoft Technology Licensing, Llc | Shared hidden layer combination for speech recognition systems |
US9384334B2 (en) | 2014-05-12 | 2016-07-05 | Microsoft Technology Licensing, Llc | Content discovery in managed wireless distribution networks |
US10111099B2 (en) | 2014-05-12 | 2018-10-23 | Microsoft Technology Licensing, Llc | Distributing content in managed wireless distribution networks |
US9430667B2 (en) | 2014-05-12 | 2016-08-30 | Microsoft Technology Licensing, Llc | Managed wireless distribution network |
US9874914B2 (en) | 2014-05-19 | 2018-01-23 | Microsoft Technology Licensing, Llc | Power management contracts for accessory devices |
US10037202B2 (en) | 2014-06-03 | 2018-07-31 | Microsoft Technology Licensing, Llc | Techniques to isolating a portion of an online computing service |
US9367490B2 (en) | 2014-06-13 | 2016-06-14 | Microsoft Technology Licensing, Llc | Reversible connector for accessory devices |
US9717006B2 (en) | 2014-06-23 | 2017-07-25 | Microsoft Technology Licensing, Llc | Device quarantine in a wireless network |
US11574621B1 (en) * | 2014-12-23 | 2023-02-07 | Amazon Technologies, Inc. | Stateless third party interactions |
US10572810B2 (en) | 2015-01-07 | 2020-02-25 | Microsoft Technology Licensing, Llc | Managing user interaction for input understanding determinations |
US9792560B2 (en) * | 2015-02-17 | 2017-10-17 | Microsoft Technology Licensing, Llc | Training systems and methods for sequence taggers |
US20160260029A1 (en) | 2015-03-06 | 2016-09-08 | Speaktoit, Inc. | Example-driven machine learning scheme for dialog system engines |
WO2016151692A1 (en) | 2015-03-20 | 2016-09-29 | 株式会社 東芝 | Tagging support device, method and program |
US11062228B2 (en) | 2015-07-06 | 2021-07-13 | Microsoft Technoiogy Licensing, LLC | Transfer learning techniques for disparate label sets |
US10249297B2 (en) * | 2015-07-13 | 2019-04-02 | Microsoft Technology Licensing, Llc | Propagating conversational alternatives using delayed hypothesis binding |
US10338959B2 (en) | 2015-07-13 | 2019-07-02 | Microsoft Technology Licensing, Llc | Task state tracking in systems and services |
US10607504B1 (en) * | 2015-09-25 | 2020-03-31 | Educational Testing Service | Computer-implemented systems and methods for a crowd source-bootstrapped spoken dialog system |
US11250218B2 (en) | 2015-12-11 | 2022-02-15 | Microsoft Technology Licensing, Llc | Personalizing natural language understanding systems |
US20170212928A1 (en) * | 2016-01-27 | 2017-07-27 | International Business Machines Corporation | Cognitive decision making based on dynamic model composition |
US10635281B2 (en) * | 2016-02-12 | 2020-04-28 | Microsoft Technology Licensing, Llc | Natural language task completion platform authoring for third party experiences |
US10095470B2 (en) | 2016-02-22 | 2018-10-09 | Sonos, Inc. | Audio response playback |
US9965247B2 (en) | 2016-02-22 | 2018-05-08 | Sonos, Inc. | Voice controlled media playback system based on user profile |
US10264030B2 (en) | 2016-02-22 | 2019-04-16 | Sonos, Inc. | Networked microphone device control |
US9947316B2 (en) | 2016-02-22 | 2018-04-17 | Sonos, Inc. | Voice control of a media playback system |
US10097919B2 (en) | 2016-02-22 | 2018-10-09 | Sonos, Inc. | Music service selection |
US10509626B2 (en) | 2016-02-22 | 2019-12-17 | Sonos, Inc | Handling of loss of pairing between networked devices |
US9978390B2 (en) | 2016-06-09 | 2018-05-22 | Sonos, Inc. | Dynamic player selection for audio signal processing |
US10474439B2 (en) * | 2016-06-16 | 2019-11-12 | Microsoft Technology Licensing, Llc | Systems and methods for building conversational understanding systems |
US9996532B2 (en) * | 2016-06-17 | 2018-06-12 | Microsoft Technology Licensing, Llc | Systems and methods for building state specific multi-turn contextual language understanding systems |
US20180005629A1 (en) * | 2016-06-30 | 2018-01-04 | Microsoft Technology Licensing, Llc | Policy authoring for task state tracking during dialogue |
US10134399B2 (en) | 2016-07-15 | 2018-11-20 | Sonos, Inc. | Contextualization of voice inputs |
US10152969B2 (en) | 2016-07-15 | 2018-12-11 | Sonos, Inc. | Voice detection by multiple devices |
US10115400B2 (en) | 2016-08-05 | 2018-10-30 | Sonos, Inc. | Multiple voice services |
US10360300B2 (en) | 2016-08-24 | 2019-07-23 | Microsoft Technology Licensing, Llc | Multi-turn cross-domain natural language understanding systems, building platforms, and methods |
US10446137B2 (en) | 2016-09-07 | 2019-10-15 | Microsoft Technology Licensing, Llc | Ambiguity resolving conversational understanding system |
US9942678B1 (en) | 2016-09-27 | 2018-04-10 | Sonos, Inc. | Audio playback settings for voice interaction |
US10102256B2 (en) | 2016-09-29 | 2018-10-16 | International Business Machines Corporation | Internet search result intention |
US9743204B1 (en) | 2016-09-30 | 2017-08-22 | Sonos, Inc. | Multi-orientation playback device microphones |
US10181323B2 (en) | 2016-10-19 | 2019-01-15 | Sonos, Inc. | Arbitration-based voice recognition |
US10649739B2 (en) * | 2016-12-20 | 2020-05-12 | Microsoft Technology Licensing, Llc | Facilitating application development |
CN106997767A (en) * | 2017-03-24 | 2017-08-01 | 百度在线网络技术(北京)有限公司 | Method of speech processing and device based on artificial intelligence |
US11183181B2 (en) | 2017-03-27 | 2021-11-23 | Sonos, Inc. | Systems and methods of multiple voice services |
US10817551B2 (en) * | 2017-04-25 | 2020-10-27 | Panasonic Intellectual Property Management Co., Ltd. | Method for expanding word, word expanding apparatus, and non-transitory computer-readable recording medium |
CN107463601B (en) * | 2017-06-13 | 2021-02-12 | 北京百度网讯科技有限公司 | Dialog understanding system construction method, device and equipment based on artificial intelligence and computer readable storage medium |
US11880761B2 (en) | 2017-07-28 | 2024-01-23 | Microsoft Technology Licensing, Llc | Domain addition systems and methods for a language understanding system |
US10475449B2 (en) | 2017-08-07 | 2019-11-12 | Sonos, Inc. | Wake-word detection suppression |
US10885900B2 (en) | 2017-08-11 | 2021-01-05 | Microsoft Technology Licensing, Llc | Domain adaptation in speech recognition via teacher-student learning |
US10048930B1 (en) | 2017-09-08 | 2018-08-14 | Sonos, Inc. | Dynamic computation of system response volume |
CN107679557B (en) * | 2017-09-19 | 2020-11-27 | 平安科技(深圳)有限公司 | Driving model training method, driver identification method, device, equipment and medium |
US10446165B2 (en) | 2017-09-27 | 2019-10-15 | Sonos, Inc. | Robust short-time fourier transform acoustic echo cancellation during audio playback |
US10482868B2 (en) | 2017-09-28 | 2019-11-19 | Sonos, Inc. | Multi-channel acoustic echo cancellation |
US10621981B2 (en) | 2017-09-28 | 2020-04-14 | Sonos, Inc. | Tone interference cancellation |
US10051366B1 (en) | 2017-09-28 | 2018-08-14 | Sonos, Inc. | Three-dimensional beam forming with a microphone array |
US10466962B2 (en) | 2017-09-29 | 2019-11-05 | Sonos, Inc. | Media playback system with voice assistance |
US11157533B2 (en) | 2017-11-08 | 2021-10-26 | International Business Machines Corporation | Designing conversational systems driven by a semantic network with a library of templated query operators |
EP3483746A1 (en) * | 2017-11-09 | 2019-05-15 | Snips | Methods and devices for generating data to train a natural language understanding component |
US10880650B2 (en) | 2017-12-10 | 2020-12-29 | Sonos, Inc. | Network microphone devices with automatic do not disturb actuation capabilities |
US10818290B2 (en) | 2017-12-11 | 2020-10-27 | Sonos, Inc. | Home graph |
WO2019148115A1 (en) | 2018-01-26 | 2019-08-01 | Ensono, Lp | Reducing latency and improving accuracy of work estimates utilizing natural language processing |
WO2019152722A1 (en) | 2018-01-31 | 2019-08-08 | Sonos, Inc. | Device designation of playback and network microphone device arrangements |
US11175880B2 (en) | 2018-05-10 | 2021-11-16 | Sonos, Inc. | Systems and methods for voice-assisted media content selection |
US10847178B2 (en) | 2018-05-18 | 2020-11-24 | Sonos, Inc. | Linear filtering for noise-suppressed speech detection |
US10959029B2 (en) | 2018-05-25 | 2021-03-23 | Sonos, Inc. | Determining and adapting to changes in microphone performance of playback devices |
US10681460B2 (en) | 2018-06-28 | 2020-06-09 | Sonos, Inc. | Systems and methods for associating playback devices with voice assistant services |
US10461710B1 (en) | 2018-08-28 | 2019-10-29 | Sonos, Inc. | Media playback system with maximum volume setting |
US11076035B2 (en) | 2018-08-28 | 2021-07-27 | Sonos, Inc. | Do not disturb feature for audio notifications |
US10587430B1 (en) | 2018-09-14 | 2020-03-10 | Sonos, Inc. | Networked devices, systems, and methods for associating playback devices based on sound codes |
US11024331B2 (en) | 2018-09-21 | 2021-06-01 | Sonos, Inc. | Voice detection optimization using sound metadata |
US10811015B2 (en) | 2018-09-25 | 2020-10-20 | Sonos, Inc. | Voice detection optimization based on selected voice assistant service |
US11100923B2 (en) | 2018-09-28 | 2021-08-24 | Sonos, Inc. | Systems and methods for selective wake word detection using neural network models |
US10692518B2 (en) | 2018-09-29 | 2020-06-23 | Sonos, Inc. | Linear filtering for noise-suppressed speech detection via multiple network microphone devices |
US11899519B2 (en) | 2018-10-23 | 2024-02-13 | Sonos, Inc. | Multiple stage network microphone device with reduced power consumption and processing load |
EP3654249A1 (en) | 2018-11-15 | 2020-05-20 | Snips | Dilated convolutions and gating for efficient keyword spotting |
US11183183B2 (en) | 2018-12-07 | 2021-11-23 | Sonos, Inc. | Systems and methods of operating media playback systems having multiple voice assistant services |
US11132989B2 (en) | 2018-12-13 | 2021-09-28 | Sonos, Inc. | Networked microphone devices, systems, and methods of localized arbitration |
US10602268B1 (en) | 2018-12-20 | 2020-03-24 | Sonos, Inc. | Optimization of network microphone devices using noise classification |
EP3903307A4 (en) * | 2018-12-27 | 2022-09-07 | Telepathy Labs, Inc. | System and method for communicating with a user with speech processing |
US10867604B2 (en) | 2019-02-08 | 2020-12-15 | Sonos, Inc. | Devices, systems, and methods for distributed voice processing |
US11315556B2 (en) | 2019-02-08 | 2022-04-26 | Sonos, Inc. | Devices, systems, and methods for distributed voice processing by transmitting sound data associated with a wake word to an appropriate device for identification |
CN109918492A (en) * | 2019-03-18 | 2019-06-21 | 百度在线网络技术(北京)有限公司 | System is arranged in a kind of human-computer dialogue setting method and human-computer dialogue |
US11120794B2 (en) | 2019-05-03 | 2021-09-14 | Sonos, Inc. | Voice assistant persistence across multiple network microphone devices |
US11151333B2 (en) * | 2019-06-11 | 2021-10-19 | Microsoft Technology Licensing Llc | Conversational event modeling |
US11170174B2 (en) | 2019-06-11 | 2021-11-09 | Microsoft Technology Licensing, Llc | Conversational AI using adaptive dialogs |
US11468122B2 (en) * | 2019-06-11 | 2022-10-11 | Microsoft Technology Licensing, Llc | Shared memory space management for conversational artificial intelligence system |
US11361756B2 (en) | 2019-06-12 | 2022-06-14 | Sonos, Inc. | Conditional wake word eventing based on environment |
EP3983909A1 (en) * | 2019-06-12 | 2022-04-20 | Liveperson, Inc. | Systems and methods for communication system intent analysis |
US11200894B2 (en) | 2019-06-12 | 2021-12-14 | Sonos, Inc. | Network microphone device with command keyword eventing |
US10586540B1 (en) | 2019-06-12 | 2020-03-10 | Sonos, Inc. | Network microphone device with command keyword conditioning |
US11138975B2 (en) | 2019-07-31 | 2021-10-05 | Sonos, Inc. | Locally distributed keyword detection |
US11138969B2 (en) | 2019-07-31 | 2021-10-05 | Sonos, Inc. | Locally distributed keyword detection |
US10871943B1 (en) | 2019-07-31 | 2020-12-22 | Sonos, Inc. | Noise classification for event detection |
US11189286B2 (en) | 2019-10-22 | 2021-11-30 | Sonos, Inc. | VAS toggle based on device orientation |
US11200900B2 (en) | 2019-12-20 | 2021-12-14 | Sonos, Inc. | Offline voice control |
WO2021137637A1 (en) | 2020-01-02 | 2021-07-08 | Samsung Electronics Co., Ltd. | Server, client device, and operation methods thereof for training natural language understanding model |
US11562740B2 (en) | 2020-01-07 | 2023-01-24 | Sonos, Inc. | Voice verification for media playback |
US11556307B2 (en) | 2020-01-31 | 2023-01-17 | Sonos, Inc. | Local voice data processing |
US11308958B2 (en) | 2020-02-07 | 2022-04-19 | Sonos, Inc. | Localized wakeword verification |
US11308962B2 (en) | 2020-05-20 | 2022-04-19 | Sonos, Inc. | Input detection windowing |
US11727919B2 (en) | 2020-05-20 | 2023-08-15 | Sonos, Inc. | Memory allocation for keyword spotting engines |
US11482224B2 (en) | 2020-05-20 | 2022-10-25 | Sonos, Inc. | Command keywords with input detection windowing |
KR102425276B1 (en) * | 2020-08-24 | 2022-07-26 | 에스케이플래닛 주식회사 | Method and apparatus for providing chatbot service |
US11698771B2 (en) | 2020-08-25 | 2023-07-11 | Sonos, Inc. | Vocal guidance engines for playback devices |
US11984123B2 (en) | 2020-11-12 | 2024-05-14 | Sonos, Inc. | Network device interaction by range |
US20220230631A1 (en) * | 2021-01-18 | 2022-07-21 | PM Labs, Inc. | System and method for conversation using spoken language understanding |
US11551700B2 (en) | 2021-01-25 | 2023-01-10 | Sonos, Inc. | Systems and methods for power-efficient keyword detection |
CN113158641A (en) * | 2021-03-26 | 2021-07-23 | 联想(北京)有限公司 | Information processing method and device |
US20230135962A1 (en) * | 2021-11-02 | 2023-05-04 | Microsoft Technology Licensing, Llc | Training framework for automated tasks involving multiple machine learning models |
Family Cites Families (138)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2631864B2 (en) | 1988-06-13 | 1997-07-16 | 大成建設株式会社 | Construction method of flat tunnel |
US5170499A (en) | 1989-03-06 | 1992-12-08 | Motorola, Inc. | Method and apparatus for adjusting the volume level of a radio |
JP3168004B2 (en) | 1991-08-19 | 2001-05-21 | レルナウト アンド ハウスピイ スピーチプロダクツ | Pattern recognition device using artificial neural network for context-dependent modeling |
US5233681A (en) | 1992-04-24 | 1993-08-03 | International Business Machines Corporation | Context-dependent speech recognizer using estimated next word context |
US6405132B1 (en) | 1997-10-22 | 2002-06-11 | Intelligent Technologies International, Inc. | Accident avoidance system |
US6167377A (en) | 1997-03-28 | 2000-12-26 | Dragon Systems, Inc. | Speech recognition language models |
KR100241901B1 (en) | 1997-08-28 | 2000-02-01 | 윤종용 | How to manage registered entries for handset and handsfree common voice recognizer |
ITTO980383A1 (en) | 1998-05-07 | 1999-11-07 | Cselt Centro Studi Lab Telecom | PROCEDURE AND VOICE RECOGNITION DEVICE WITH DOUBLE STEP OF NEURAL AND MARKOVIAN RECOGNITION. |
DE69937962T2 (en) * | 1998-10-02 | 2008-12-24 | International Business Machines Corp. | DEVICE AND METHOD FOR PROVIDING NETWORK COORDINATED CONVERSION SERVICES |
US20050091057A1 (en) * | 1999-04-12 | 2005-04-28 | General Magic, Inc. | Voice application development methodology |
US6647270B1 (en) | 1999-09-10 | 2003-11-11 | Richard B. Himmelstein | Vehicletalk |
US7392185B2 (en) * | 1999-11-12 | 2008-06-24 | Phoenix Solutions, Inc. | Speech based learning/training system using semantic decoding |
US6263308B1 (en) | 2000-03-20 | 2001-07-17 | Microsoft Corporation | Methods and apparatus for performing speech recognition using acoustic models which are improved through an interactive process |
US7788602B2 (en) * | 2000-06-06 | 2010-08-31 | Microsoft Corporation | Method and system for providing restricted actions for recognized semantic categories |
ATE261137T1 (en) | 2000-06-29 | 2004-03-15 | Aspen Technology Inc | COMPUTER METHOD AND DEVICE FOR LIMITING A NON-LINEAR EQUATION APPROXIMATION OF AN EMPIRICAL PROCESS |
JP2002091477A (en) | 2000-09-14 | 2002-03-27 | Mitsubishi Electric Corp | Voice recognition system, voice recognition device, acoustic model control server, language model control server, voice recognition method and computer readable recording medium which records voice recognition program |
US6807536B2 (en) | 2000-11-16 | 2004-10-19 | Microsoft Corporation | Methods and systems for computing singular value decompositions of matrices and low rank approximations of matrices |
US6622136B2 (en) * | 2001-02-16 | 2003-09-16 | Motorola, Inc. | Interactive tool for semi-automatic creation of a domain model |
US20050234727A1 (en) * | 2001-07-03 | 2005-10-20 | Leo Chiu | Method and apparatus for adapting a voice extensible markup language-enabled voice system for natural speech recognition and system response |
US6970947B2 (en) | 2001-07-18 | 2005-11-29 | International Business Machines Corporation | Method and apparatus for providing a flexible and scalable context service |
US20030149566A1 (en) | 2002-01-02 | 2003-08-07 | Esther Levin | System and method for a spoken language interface to a large database of changing records |
JP2003280683A (en) | 2002-03-20 | 2003-10-02 | Toshiba Corp | Voice recognition device, voice recognition control method of the device, and dictionary controller related to voice processing |
US7006972B2 (en) | 2002-03-20 | 2006-02-28 | Microsoft Corporation | Generating a task-adapted acoustic model from one or more different corpora |
US7191119B2 (en) * | 2002-05-07 | 2007-03-13 | International Business Machines Corporation | Integrated development tool for building a natural language understanding application |
US7548847B2 (en) * | 2002-05-10 | 2009-06-16 | Microsoft Corporation | System for automatically annotating training data for a natural language understanding system |
US7398209B2 (en) | 2002-06-03 | 2008-07-08 | Voicebox Technologies, Inc. | Systems and methods for responding to natural language speech utterance |
US7756531B2 (en) | 2002-09-04 | 2010-07-13 | Farhad John Aminzadeh | Method and apparatus for avoiding call disturbances and facilitating urgent calls based on a caller's decision |
US7274741B2 (en) | 2002-11-01 | 2007-09-25 | Microsoft Corporation | Systems and methods for generating a comprehensive user attention model |
JP2004227468A (en) | 2003-01-27 | 2004-08-12 | Canon Inc | Information provision device and information provision method |
US20040176083A1 (en) | 2003-02-25 | 2004-09-09 | Motorola, Inc. | Method and system for reducing distractions of mobile device users |
US7366655B1 (en) * | 2003-04-02 | 2008-04-29 | At&T Corp. | Method of generating a labeling guide for spoken dialog services |
US7835910B1 (en) * | 2003-05-29 | 2010-11-16 | At&T Intellectual Property Ii, L.P. | Exploiting unlabeled utterances for spoken language understanding |
CA2473195C (en) | 2003-07-29 | 2014-02-04 | Microsoft Corporation | Head mounted multi-sensory audio input system |
CN1830025A (en) | 2003-08-01 | 2006-09-06 | 皇家飞利浦电子股份有限公司 | Method for driving a dialog system |
US20050065789A1 (en) | 2003-09-23 | 2005-03-24 | Sherif Yacoub | System and method with automated speech recognition engines |
US7774196B2 (en) | 2003-10-01 | 2010-08-10 | Dictaphone Corporation | System and method for modifying a language model and post-processor information |
JP2005157494A (en) | 2003-11-20 | 2005-06-16 | Aruze Corp | Conversation control device and conversation control method |
JP5255769B2 (en) | 2003-11-21 | 2013-08-07 | ニュアンス コミュニケーションズ オーストリア ゲーエムベーハー | Topic-specific models for text formatting and speech recognition |
CN100539763C (en) | 2003-11-27 | 2009-09-09 | 国际商业机器公司 | Control is from the method for wireless communication of moving vehicle |
JP4581441B2 (en) | 2004-03-18 | 2010-11-17 | パナソニック株式会社 | Home appliance system, home appliance and voice recognition method |
US8412521B2 (en) | 2004-08-20 | 2013-04-02 | Multimodal Technologies, Llc | Discriminative training of document transcription system |
US7693713B2 (en) | 2005-06-17 | 2010-04-06 | Microsoft Corporation | Speech models generated using competitive training, asymmetric training, and data boosting |
US7640160B2 (en) | 2005-08-05 | 2009-12-29 | Voicebox Technologies, Inc. | Systems and methods for responding to natural language speech utterance |
US7620549B2 (en) | 2005-08-10 | 2009-11-17 | Voicebox Technologies, Inc. | System and method of supporting adaptive misrecognition in conversational speech |
US8321220B1 (en) * | 2005-11-30 | 2012-11-27 | At&T Intellectual Property Ii, L.P. | System and method of semi-supervised learning for spoken language understanding using semantic role labeling |
US20070128979A1 (en) | 2005-12-07 | 2007-06-07 | J. Shackelford Associates Llc. | Interactive Hi-Tech doll |
US7835911B2 (en) | 2005-12-30 | 2010-11-16 | Nuance Communications, Inc. | Method and system for automatically building natural language understanding models |
US7603330B2 (en) | 2006-02-01 | 2009-10-13 | Honda Motor Co., Ltd. | Meta learning for question classification |
DE102006006551B4 (en) * | 2006-02-13 | 2008-09-11 | Siemens Ag | Method and system for providing voice dialogue applications and mobile terminal |
IL174522A0 (en) | 2006-03-23 | 2006-08-01 | Jonathan Agmon | Method for predictive typing |
JP2007264128A (en) | 2006-03-27 | 2007-10-11 | Toshiba Corp | Voice recognition device and its method |
US7627536B2 (en) * | 2006-06-13 | 2009-12-01 | Microsoft Corporation | Dynamic interaction menus from natural language representations |
US7716049B2 (en) | 2006-06-30 | 2010-05-11 | Nokia Corporation | Method, apparatus and computer program product for providing adaptive language model scaling |
US9318108B2 (en) | 2010-01-18 | 2016-04-19 | Apple Inc. | Intelligent automated assistant |
WO2008081543A1 (en) | 2006-12-28 | 2008-07-10 | Fujitsu Limited | Portable terminal, its conversation control program, recording medium storing the conversation control program, and its conversation control method |
US7912700B2 (en) | 2007-02-08 | 2011-03-22 | Microsoft Corporation | Context based word prediction |
TW200836893A (en) | 2007-03-01 | 2008-09-16 | Benq Corp | Interactive home entertainment robot and method of controlling the same |
US8838457B2 (en) | 2007-03-07 | 2014-09-16 | Vlingo Corporation | Using results of unstructured language model based speech recognition to control a system-level function of a mobile communications facility |
US20090030697A1 (en) | 2007-03-07 | 2009-01-29 | Cerra Joseph P | Using contextual information for delivering results generated from a speech recognition facility using an unstructured language model |
US20070150428A1 (en) | 2007-03-20 | 2007-06-28 | Brandyn Webb | Inference engine for discovering features and making predictions using generalized incremental singular value decomposition |
JP2008233678A (en) | 2007-03-22 | 2008-10-02 | Honda Motor Co Ltd | Voice interaction apparatus, voice interaction method, and program for voice interaction |
US8301757B2 (en) * | 2007-06-11 | 2012-10-30 | Enghouse Interactive Inc. | System and method for obtaining in-use statistics for voice applications in interactive voice response systems |
US8275615B2 (en) | 2007-07-13 | 2012-09-25 | International Business Machines Corporation | Model weighting, selection and hypotheses combination for automatic speech recognition and machine translation |
JP2009075582A (en) | 2007-08-29 | 2009-04-09 | Advanced Media Inc | Terminal device, language model creation device, and distributed speech recognition system |
CN101415039A (en) | 2007-10-17 | 2009-04-22 | 宏达国际电子股份有限公司 | call management method |
JP2009230068A (en) | 2008-03-25 | 2009-10-08 | Denso Corp | Voice recognition device and navigation system |
US8229729B2 (en) | 2008-03-25 | 2012-07-24 | International Business Machines Corporation | Machine translation in continuous space |
US8332394B2 (en) | 2008-05-23 | 2012-12-11 | International Business Machines Corporation | System and method for providing question and answers with deferred type evaluation |
US8364481B2 (en) | 2008-07-02 | 2013-01-29 | Google Inc. | Speech recognition with parallel recognition tasks |
US8412529B2 (en) * | 2008-10-29 | 2013-04-02 | Verizon Patent And Licensing Inc. | Method and system for enhancing verbal communication sessions |
US20100114890A1 (en) | 2008-10-31 | 2010-05-06 | Purediscovery Corporation | System and Method for Discovering Latent Relationships in Data |
KR101537078B1 (en) | 2008-11-05 | 2015-07-15 | 구글 인코포레이티드 | Custom language models |
CN102272755A (en) | 2008-11-07 | 2011-12-07 | 琳古佩迪亚投资责任有限公司 | Method for semantic processing of natural language using graphical interlingua |
US20100128863A1 (en) | 2008-11-21 | 2010-05-27 | Robert Bosch Gmbh | Context aware voice communication proxy |
US8447608B1 (en) | 2008-12-10 | 2013-05-21 | Adobe Systems Incorporated | Custom language models for audio content |
WO2010092486A1 (en) | 2009-02-16 | 2010-08-19 | Comverse, Ltd. | Context-aware communications |
US8930179B2 (en) | 2009-06-04 | 2015-01-06 | Microsoft Corporation | Recognition using re-recognition and statistical classification |
US9177557B2 (en) | 2009-07-07 | 2015-11-03 | General Motors Llc. | Singular value decomposition for improved voice recognition in presence of multi-talker background noise |
US8886641B2 (en) | 2009-10-15 | 2014-11-11 | Yahoo! Inc. | Incorporating recency in network search using machine learning |
US8571866B2 (en) | 2009-10-23 | 2013-10-29 | At&T Intellectual Property I, L.P. | System and method for improving speech recognition accuracy using textual context |
KR101622111B1 (en) | 2009-12-11 | 2016-05-18 | 삼성전자 주식회사 | Dialog system and conversational method thereof |
US8249627B2 (en) | 2009-12-21 | 2012-08-21 | Julia Olincy | “I am driving/busy” automatic response system for mobile phones |
US8315597B2 (en) | 2009-12-21 | 2012-11-20 | Julia Olincy | “I am driving/busy” automatic response system for mobile phones |
EP2339576B1 (en) | 2009-12-23 | 2019-08-07 | Google LLC | Multi-modal input on an electronic device |
US8400332B2 (en) | 2010-02-09 | 2013-03-19 | Ford Global Technologies, Llc | Emotive advisory system including time agent |
JP2012038239A (en) | 2010-08-11 | 2012-02-23 | Sony Corp | Information processing equipment, information processing method and program |
US8972253B2 (en) | 2010-09-15 | 2015-03-03 | Microsoft Technology Licensing, Llc | Deep belief network for large vocabulary continuous speech recognition |
FR2965377A1 (en) | 2010-09-24 | 2012-03-30 | Univ D Avignon Et Des Pays De Vaucluse | METHOD FOR CLASSIFYING BIOMETRIC DATA |
JP2012075047A (en) | 2010-09-29 | 2012-04-12 | Toshiba Corp | Ip exchange system and ip exchanger |
US8812321B2 (en) | 2010-09-30 | 2014-08-19 | At&T Intellectual Property I, L.P. | System and method for combining speech recognition outputs from a plurality of domain-specific speech recognizers via machine learning |
JP5704692B2 (en) | 2010-11-30 | 2015-04-22 | 独立行政法人情報通信研究機構 | Pattern classification device learning device and computer program therefor |
US8352245B1 (en) | 2010-12-30 | 2013-01-08 | Google Inc. | Adjusting language models |
JP5861649B2 (en) | 2011-02-03 | 2016-02-16 | 日本電気株式会社 | Model adaptation device, model adaptation method, and model adaptation program |
US9081760B2 (en) | 2011-03-08 | 2015-07-14 | At&T Intellectual Property I, L.P. | System and method for building diverse language models |
US9679561B2 (en) | 2011-03-28 | 2017-06-13 | Nuance Communications, Inc. | System and method for rapid customization of speech recognition models |
KR101963915B1 (en) | 2011-03-31 | 2019-03-29 | 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 | Augmented conversational understanding architecture |
US8489529B2 (en) | 2011-03-31 | 2013-07-16 | Microsoft Corporation | Deep convex network with joint use of nonlinear random projection, Restricted Boltzmann Machine and batch-based parallelizable optimization |
US10642934B2 (en) | 2011-03-31 | 2020-05-05 | Microsoft Technology Licensing, Llc | Augmented conversational understanding architecture |
US9244984B2 (en) | 2011-03-31 | 2016-01-26 | Microsoft Technology Licensing, Llc | Location based conversational understanding |
US8260615B1 (en) | 2011-04-25 | 2012-09-04 | Google Inc. | Cross-lingual initialization of language models |
US20120290293A1 (en) | 2011-05-13 | 2012-11-15 | Microsoft Corporation | Exploiting Query Click Logs for Domain Detection in Spoken Language Understanding |
US8918352B2 (en) | 2011-05-23 | 2014-12-23 | Microsoft Corporation | Learning processes for single hidden layer neural networks with linear output units |
US20130031476A1 (en) | 2011-07-25 | 2013-01-31 | Coin Emmett | Voice activated virtual assistant |
KR20130022513A (en) | 2011-08-24 | 2013-03-07 | 한국전자통신연구원 | Speaker adaptation method based on joint bilinear transformation space and apparatus therefor |
DE102012019178A1 (en) | 2011-09-30 | 2013-04-04 | Apple Inc. | Use of context information to facilitate the handling of commands in a virtual assistant |
US8698621B2 (en) | 2011-11-22 | 2014-04-15 | Verizon Patent And Licensing Inc. | Method and system for providing notifications of a mobile device in motion to determine call treatment |
US9235799B2 (en) | 2011-11-26 | 2016-01-12 | Microsoft Technology Licensing, Llc | Discriminative pretraining of deep neural networks |
US9082402B2 (en) | 2011-12-08 | 2015-07-14 | Sri International | Generic virtual personal assistant platform |
US9324323B1 (en) | 2012-01-13 | 2016-04-26 | Google Inc. | Speech recognition using topic-specific language models |
US9263040B2 (en) | 2012-01-17 | 2016-02-16 | GM Global Technology Operations LLC | Method and system for using sound related vehicle information to enhance speech recognition |
JP2012128440A (en) | 2012-02-06 | 2012-07-05 | Denso Corp | Voice interactive device |
CN102609264A (en) * | 2012-02-14 | 2012-07-25 | 深圳市同洲视讯传媒有限公司 | Method and device for generating calling codes by calling application programming interfaces |
WO2013149123A1 (en) | 2012-03-30 | 2013-10-03 | The Ohio State University | Monaural speech filter |
US8346563B1 (en) | 2012-04-10 | 2013-01-01 | Artificial Solutions Ltd. | System and methods for delivering advanced natural language interaction applications |
GB201208373D0 (en) | 2012-05-14 | 2012-06-27 | Touchtype Ltd | Mechanism for synchronising devices,system and method |
US8600525B1 (en) | 2012-05-31 | 2013-12-03 | Honeywell Asca Inc. | Efficient quadratic programming (QP) solver for process control and optimization |
US9053708B2 (en) | 2012-07-18 | 2015-06-09 | International Business Machines Corporation | System, method and program product for providing automatic speech recognition (ASR) in a shared resource environment |
US9424840B1 (en) | 2012-08-31 | 2016-08-23 | Amazon Technologies, Inc. | Speech recognition platforms |
US8527276B1 (en) | 2012-10-25 | 2013-09-03 | Google Inc. | Speech synthesis using deep neural networks |
US10282419B2 (en) | 2012-12-12 | 2019-05-07 | Nuance Communications, Inc. | Multi-domain natural language processing architecture |
KR101559124B1 (en) | 2013-02-28 | 2015-10-12 | 한양대학교 산학협력단 | Cathod active material for lithium sulfur battery, lithium sulfur battery including the same, and manufacturing method of the same |
US9177550B2 (en) | 2013-03-06 | 2015-11-03 | Microsoft Technology Licensing, Llc | Conservatively adapting a deep neural network in a recognition system |
US9802693B2 (en) | 2013-06-14 | 2017-10-31 | The Boeing Company | Control surface calibration system |
US9728184B2 (en) | 2013-06-18 | 2017-08-08 | Microsoft Technology Licensing, Llc | Restructuring deep neural network acoustic models |
US9311298B2 (en) | 2013-06-21 | 2016-04-12 | Microsoft Technology Licensing, Llc | Building conversational understanding systems using a toolset |
US9589565B2 (en) | 2013-06-21 | 2017-03-07 | Microsoft Technology Licensing, Llc | Environmentally aware dialog policies and response generation |
CN103400577B (en) | 2013-08-01 | 2015-09-16 | 百度在线网络技术(北京)有限公司 | The acoustic model method for building up of multilingual speech recognition and device |
CN103456299B (en) | 2013-08-01 | 2016-06-15 | 百度在线网络技术(北京)有限公司 | A kind of method and device controlling speech recognition |
US9280968B2 (en) | 2013-10-04 | 2016-03-08 | At&T Intellectual Property I, L.P. | System and method of using neural transforms of robust audio features for speech processing |
US9721561B2 (en) | 2013-12-05 | 2017-08-01 | Nuance Communications, Inc. | Method and apparatus for speech recognition using neural networks with speaker adaptation |
US9373324B2 (en) | 2013-12-06 | 2016-06-21 | International Business Machines Corporation | Applying speaker adaption techniques to correlated features |
US9400955B2 (en) | 2013-12-13 | 2016-07-26 | Amazon Technologies, Inc. | Reducing dynamic range of low-rank decomposition matrices |
KR101937655B1 (en) | 2013-12-31 | 2019-01-11 | 코오롱인더스트리 주식회사 | Composite Hollow Fiber Membrane and Method for Manufacturing The Same |
US10339920B2 (en) | 2014-03-04 | 2019-07-02 | Amazon Technologies, Inc. | Predicting pronunciation in speech recognition |
US9324321B2 (en) | 2014-03-07 | 2016-04-26 | Microsoft Technology Licensing, Llc | Low-footprint adaptation and personalization for a deep neural network |
US9529794B2 (en) | 2014-03-27 | 2016-12-27 | Microsoft Technology Licensing, Llc | Flexible schema for language model customization |
US9520127B2 (en) | 2014-04-29 | 2016-12-13 | Microsoft Technology Licensing, Llc | Shared hidden layer combination for speech recognition systems |
US20150325236A1 (en) | 2014-05-08 | 2015-11-12 | Microsoft Corporation | Context specific language model scale factors |
-
2013
- 2013-06-21 US US13/923,969 patent/US9311298B2/en active Active
-
2014
- 2014-06-05 KR KR1020157035936A patent/KR102303483B1/en active Active
- 2014-06-05 WO PCT/US2014/041023 patent/WO2014204659A2/en active Application Filing
- 2014-06-05 CN CN201910428922.5A patent/CN110263327B/en active Active
- 2014-06-05 CN CN201480035400.4A patent/CN105474170B/en active Active
- 2014-06-05 KR KR1020217029117A patent/KR102406236B1/en active Active
- 2014-06-05 EP EP14736143.0A patent/EP3011472A2/en not_active Ceased
-
2016
- 2016-03-21 US US15/076,125 patent/US9697200B2/en active Active
-
2017
- 2017-05-22 US US15/600,995 patent/US10572602B2/en active Active
Non-Patent Citations (1)
Title |
---|
None |
Cited By (239)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11928604B2 (en) | 2005-09-08 | 2024-03-12 | Apple Inc. | Method and apparatus for building an intelligent automated assistant |
US10318871B2 (en) | 2005-09-08 | 2019-06-11 | Apple Inc. | Method and apparatus for building an intelligent automated assistant |
US11671920B2 (en) | 2007-04-03 | 2023-06-06 | Apple Inc. | Method and system for operating a multifunction portable electronic device using voice-activation |
US11979836B2 (en) | 2007-04-03 | 2024-05-07 | Apple Inc. | Method and system for operating a multi-function portable electronic device using voice-activation |
US11023513B2 (en) | 2007-12-20 | 2021-06-01 | Apple Inc. | Method and apparatus for searching using an active ontology |
US10381016B2 (en) | 2008-01-03 | 2019-08-13 | Apple Inc. | Methods and apparatus for altering audio output signals |
US9865248B2 (en) | 2008-04-05 | 2018-01-09 | Apple Inc. | Intelligent text-to-speech conversion |
US10108612B2 (en) | 2008-07-31 | 2018-10-23 | Apple Inc. | Mobile device having human language translation capability with positional feedback |
US11900936B2 (en) | 2008-10-02 | 2024-02-13 | Apple Inc. | Electronic devices with voice command and contextual data processing capabilities |
US10643611B2 (en) | 2008-10-02 | 2020-05-05 | Apple Inc. | Electronic devices with voice command and contextual data processing capabilities |
US11348582B2 (en) | 2008-10-02 | 2022-05-31 | Apple Inc. | Electronic devices with voice command and contextual data processing capabilities |
US11080012B2 (en) | 2009-06-05 | 2021-08-03 | Apple Inc. | Interface for a virtual digital assistant |
US10795541B2 (en) | 2009-06-05 | 2020-10-06 | Apple Inc. | Intelligent organization of tasks items |
US10741185B2 (en) | 2010-01-18 | 2020-08-11 | Apple Inc. | Intelligent automated assistant |
US12087308B2 (en) | 2010-01-18 | 2024-09-10 | Apple Inc. | Intelligent automated assistant |
US12165635B2 (en) | 2010-01-18 | 2024-12-10 | Apple Inc. | Intelligent automated assistant |
US10706841B2 (en) | 2010-01-18 | 2020-07-07 | Apple Inc. | Task flow identification based on user intent |
US11423886B2 (en) | 2010-01-18 | 2022-08-23 | Apple Inc. | Task flow identification based on user intent |
US10692504B2 (en) | 2010-02-25 | 2020-06-23 | Apple Inc. | User profiling for voice input processing |
US10049675B2 (en) | 2010-02-25 | 2018-08-14 | Apple Inc. | User profiling for voice input processing |
US10417405B2 (en) | 2011-03-21 | 2019-09-17 | Apple Inc. | Device access using voice authentication |
US11120372B2 (en) | 2011-06-03 | 2021-09-14 | Apple Inc. | Performing actions associated with task items that represent tasks to perform |
US11350253B2 (en) | 2011-06-03 | 2022-05-31 | Apple Inc. | Active transport based notifications |
US11069336B2 (en) | 2012-03-02 | 2021-07-20 | Apple Inc. | Systems and methods for name pronunciation |
US11321116B2 (en) | 2012-05-15 | 2022-05-03 | Apple Inc. | Systems and methods for integrating third party services with a digital assistant |
US11269678B2 (en) | 2012-05-15 | 2022-03-08 | Apple Inc. | Systems and methods for integrating third party services with a digital assistant |
US10079014B2 (en) | 2012-06-08 | 2018-09-18 | Apple Inc. | Name recognition system |
US9971774B2 (en) | 2012-09-19 | 2018-05-15 | Apple Inc. | Voice-based media searching |
US11557310B2 (en) | 2013-02-07 | 2023-01-17 | Apple Inc. | Voice trigger for a digital assistant |
US12009007B2 (en) | 2013-02-07 | 2024-06-11 | Apple Inc. | Voice trigger for a digital assistant |
US10714117B2 (en) | 2013-02-07 | 2020-07-14 | Apple Inc. | Voice trigger for a digital assistant |
US11862186B2 (en) | 2013-02-07 | 2024-01-02 | Apple Inc. | Voice trigger for a digital assistant |
US10978090B2 (en) | 2013-02-07 | 2021-04-13 | Apple Inc. | Voice trigger for a digital assistant |
US11636869B2 (en) | 2013-02-07 | 2023-04-25 | Apple Inc. | Voice trigger for a digital assistant |
US11388291B2 (en) | 2013-03-14 | 2022-07-12 | Apple Inc. | System and method for processing voicemail |
US11798547B2 (en) | 2013-03-15 | 2023-10-24 | Apple Inc. | Voice activated device for use with a voice-based digital assistant |
US9966060B2 (en) | 2013-06-07 | 2018-05-08 | Apple Inc. | System and method for user-specified pronunciation of words for speech synthesis and recognition |
US10657961B2 (en) | 2013-06-08 | 2020-05-19 | Apple Inc. | Interpreting and acting upon commands that involve sharing information with remote devices |
US11048473B2 (en) | 2013-06-09 | 2021-06-29 | Apple Inc. | Device, method, and graphical user interface for enabling conversation persistence across two or more instances of a digital assistant |
US10769385B2 (en) | 2013-06-09 | 2020-09-08 | Apple Inc. | System and method for inferring user intent from speech inputs |
US11727219B2 (en) | 2013-06-09 | 2023-08-15 | Apple Inc. | System and method for inferring user intent from speech inputs |
US12073147B2 (en) | 2013-06-09 | 2024-08-27 | Apple Inc. | Device, method, and graphical user interface for enabling conversation persistence across two or more instances of a digital assistant |
US12010262B2 (en) | 2013-08-06 | 2024-06-11 | Apple Inc. | Auto-activating smart responses based on activities from remote devices |
US11314370B2 (en) | 2013-12-06 | 2022-04-26 | Apple Inc. | Method for extracting salient dialog usage from live data |
US11133008B2 (en) | 2014-05-30 | 2021-09-28 | Apple Inc. | Reducing the need for manual start/end-pointing and trigger phrases |
US12067990B2 (en) | 2014-05-30 | 2024-08-20 | Apple Inc. | Intelligent assistant for home automation |
US12118999B2 (en) | 2014-05-30 | 2024-10-15 | Apple Inc. | Reducing the need for manual start/end-pointing and trigger phrases |
US11699448B2 (en) | 2014-05-30 | 2023-07-11 | Apple Inc. | Intelligent assistant for home automation |
US10878809B2 (en) | 2014-05-30 | 2020-12-29 | Apple Inc. | Multi-command single utterance input method |
US10497365B2 (en) | 2014-05-30 | 2019-12-03 | Apple Inc. | Multi-command single utterance input method |
US11257504B2 (en) | 2014-05-30 | 2022-02-22 | Apple Inc. | Intelligent assistant for home automation |
US11670289B2 (en) | 2014-05-30 | 2023-06-06 | Apple Inc. | Multi-command single utterance input method |
US10083690B2 (en) | 2014-05-30 | 2018-09-25 | Apple Inc. | Better resolution when referencing to concepts |
US11810562B2 (en) | 2014-05-30 | 2023-11-07 | Apple Inc. | Reducing the need for manual start/end-pointing and trigger phrases |
US10714095B2 (en) | 2014-05-30 | 2020-07-14 | Apple Inc. | Intelligent assistant for home automation |
US10699717B2 (en) | 2014-05-30 | 2020-06-30 | Apple Inc. | Intelligent assistant for home automation |
US10657966B2 (en) | 2014-05-30 | 2020-05-19 | Apple Inc. | Better resolution when referencing to concepts |
US10417344B2 (en) | 2014-05-30 | 2019-09-17 | Apple Inc. | Exemplar-based natural language processing |
US11838579B2 (en) | 2014-06-30 | 2023-12-05 | Apple Inc. | Intelligent automated assistant for TV user interactions |
US10904611B2 (en) | 2014-06-30 | 2021-01-26 | Apple Inc. | Intelligent automated assistant for TV user interactions |
US12200297B2 (en) | 2014-06-30 | 2025-01-14 | Apple Inc. | Intelligent automated assistant for TV user interactions |
US11516537B2 (en) | 2014-06-30 | 2022-11-29 | Apple Inc. | Intelligent automated assistant for TV user interactions |
US10431204B2 (en) | 2014-09-11 | 2019-10-01 | Apple Inc. | Method and apparatus for discovering trending terms in speech requests |
US10453443B2 (en) | 2014-09-30 | 2019-10-22 | Apple Inc. | Providing an indication of the suitability of speech recognition |
US10438595B2 (en) | 2014-09-30 | 2019-10-08 | Apple Inc. | Speaker identification and unsupervised speaker adaptation techniques |
US10390213B2 (en) | 2014-09-30 | 2019-08-20 | Apple Inc. | Social reminders |
US9986419B2 (en) | 2014-09-30 | 2018-05-29 | Apple Inc. | Social reminders |
KR102451437B1 (en) | 2015-01-30 | 2022-10-05 | 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 | Techniques for updating language understanding classifier models for digital personal assistants based on crowdsourcing |
AU2016211903B2 (en) * | 2015-01-30 | 2020-07-09 | Microsoft Technology Licensing, Llc | Updating language understanding classifier models for a digital personal assistant based on crowd-sourcing |
US9508339B2 (en) | 2015-01-30 | 2016-11-29 | Microsoft Technology Licensing, Llc | Updating language understanding classifier models for a digital personal assistant based on crowd-sourcing |
KR20170115501A (en) * | 2015-01-30 | 2017-10-17 | 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 | Techniques to update the language understanding categorizer model for digital personal assistants based on crowdsourcing |
JP2018513431A (en) * | 2015-01-30 | 2018-05-24 | マイクロソフト テクノロジー ライセンシング,エルエルシー | Updating language understanding classifier model for digital personal assistant based on crowdsourcing |
WO2016122902A3 (en) * | 2015-01-30 | 2016-10-27 | Microsoft Technology Licensing, Llc | Updating language understanding classifier models for a digital personal assistant based on crowd-sourcing |
US11231904B2 (en) | 2015-03-06 | 2022-01-25 | Apple Inc. | Reducing response latency of intelligent automated assistants |
US12236952B2 (en) | 2015-03-08 | 2025-02-25 | Apple Inc. | Virtual assistant activation |
US10567477B2 (en) | 2015-03-08 | 2020-02-18 | Apple Inc. | Virtual assistant continuity |
US11087759B2 (en) | 2015-03-08 | 2021-08-10 | Apple Inc. | Virtual assistant activation |
US11842734B2 (en) | 2015-03-08 | 2023-12-12 | Apple Inc. | Virtual assistant activation |
US10529332B2 (en) | 2015-03-08 | 2020-01-07 | Apple Inc. | Virtual assistant activation |
US10311871B2 (en) | 2015-03-08 | 2019-06-04 | Apple Inc. | Competing devices responding to voice triggers |
US10930282B2 (en) | 2015-03-08 | 2021-02-23 | Apple Inc. | Competing devices responding to voice triggers |
US12001933B2 (en) | 2015-05-15 | 2024-06-04 | Apple Inc. | Virtual assistant in a communication session |
US11468282B2 (en) | 2015-05-15 | 2022-10-11 | Apple Inc. | Virtual assistant in a communication session |
US12154016B2 (en) | 2015-05-15 | 2024-11-26 | Apple Inc. | Virtual assistant in a communication session |
US11070949B2 (en) | 2015-05-27 | 2021-07-20 | Apple Inc. | Systems and methods for proactively identifying and surfacing relevant content on an electronic device with a touch-sensitive display |
US11127397B2 (en) | 2015-05-27 | 2021-09-21 | Apple Inc. | Device voice control |
US10681212B2 (en) | 2015-06-05 | 2020-06-09 | Apple Inc. | Virtual assistant aided communication with 3rd party service in a communication session |
US10356243B2 (en) | 2015-06-05 | 2019-07-16 | Apple Inc. | Virtual assistant aided communication with 3rd party service in a communication session |
US11025565B2 (en) | 2015-06-07 | 2021-06-01 | Apple Inc. | Personalized prediction of responses for instant messaging |
US11947873B2 (en) | 2015-06-29 | 2024-04-02 | Apple Inc. | Virtual assistant for media playback |
US11010127B2 (en) | 2015-06-29 | 2021-05-18 | Apple Inc. | Virtual assistant for media playback |
US11809483B2 (en) | 2015-09-08 | 2023-11-07 | Apple Inc. | Intelligent automated assistant for media search and playback |
US12204932B2 (en) | 2015-09-08 | 2025-01-21 | Apple Inc. | Distributed personal assistant |
US11853536B2 (en) | 2015-09-08 | 2023-12-26 | Apple Inc. | Intelligent automated assistant in a media environment |
US11500672B2 (en) | 2015-09-08 | 2022-11-15 | Apple Inc. | Distributed personal assistant |
US11954405B2 (en) | 2015-09-08 | 2024-04-09 | Apple Inc. | Zero latency digital assistant |
US11126400B2 (en) | 2015-09-08 | 2021-09-21 | Apple Inc. | Zero latency digital assistant |
US11550542B2 (en) | 2015-09-08 | 2023-01-10 | Apple Inc. | Zero latency digital assistant |
US12051413B2 (en) | 2015-09-30 | 2024-07-30 | Apple Inc. | Intelligent device identification |
US11809886B2 (en) | 2015-11-06 | 2023-11-07 | Apple Inc. | Intelligent automated assistant in a messaging environment |
US11526368B2 (en) | 2015-11-06 | 2022-12-13 | Apple Inc. | Intelligent automated assistant in a messaging environment |
US11886805B2 (en) | 2015-11-09 | 2024-01-30 | Apple Inc. | Unconventional virtual assistant interactions |
US10354652B2 (en) | 2015-12-02 | 2019-07-16 | Apple Inc. | Applying neural network language models to weighted finite state transducers for automatic speech recognition |
US10942703B2 (en) | 2015-12-23 | 2021-03-09 | Apple Inc. | Proactive assistance based on dialog communication between devices |
CN108369581A (en) * | 2016-01-23 | 2018-08-03 | 微软技术许可有限责任公司 | Support the tool of the exploitation of new language understanding scene |
US10417346B2 (en) | 2016-01-23 | 2019-09-17 | Microsoft Technology Licensing, Llc | Tool for facilitating the development of new language understanding scenarios |
WO2017127321A1 (en) * | 2016-01-23 | 2017-07-27 | Microsoft Technology Licensing, Llc | Tool for facilitating the development of new language understanding scenarios |
US10249300B2 (en) | 2016-06-06 | 2019-04-02 | Apple Inc. | Intelligent list reading |
US11227589B2 (en) | 2016-06-06 | 2022-01-18 | Apple Inc. | Intelligent list reading |
US11069347B2 (en) | 2016-06-08 | 2021-07-20 | Apple Inc. | Intelligent automated assistant for media exploration |
US10354011B2 (en) | 2016-06-09 | 2019-07-16 | Apple Inc. | Intelligent automated assistant in a home environment |
US12223282B2 (en) | 2016-06-09 | 2025-02-11 | Apple Inc. | Intelligent automated assistant in a home environment |
US10067938B2 (en) | 2016-06-10 | 2018-09-04 | Apple Inc. | Multilingual word prediction |
US11037565B2 (en) | 2016-06-10 | 2021-06-15 | Apple Inc. | Intelligent digital assistant in a multi-tasking environment |
US10733993B2 (en) | 2016-06-10 | 2020-08-04 | Apple Inc. | Intelligent digital assistant in a multi-tasking environment |
US11657820B2 (en) | 2016-06-10 | 2023-05-23 | Apple Inc. | Intelligent digital assistant in a multi-tasking environment |
US12175977B2 (en) | 2016-06-10 | 2024-12-24 | Apple Inc. | Intelligent digital assistant in a multi-tasking environment |
US11809783B2 (en) | 2016-06-11 | 2023-11-07 | Apple Inc. | Intelligent device arbitration and control |
US12197817B2 (en) | 2016-06-11 | 2025-01-14 | Apple Inc. | Intelligent device arbitration and control |
US11152002B2 (en) | 2016-06-11 | 2021-10-19 | Apple Inc. | Application integration with a digital assistant |
US10297253B2 (en) | 2016-06-11 | 2019-05-21 | Apple Inc. | Application integration with a digital assistant |
US10269345B2 (en) | 2016-06-11 | 2019-04-23 | Apple Inc. | Intelligent task discovery |
US11749275B2 (en) | 2016-06-11 | 2023-09-05 | Apple Inc. | Application integration with a digital assistant |
US10942702B2 (en) | 2016-06-11 | 2021-03-09 | Apple Inc. | Intelligent device arbitration and control |
US10580409B2 (en) | 2016-06-11 | 2020-03-03 | Apple Inc. | Application integration with a digital assistant |
US10474753B2 (en) | 2016-09-07 | 2019-11-12 | Apple Inc. | Language identification using recurrent neural networks |
US10043516B2 (en) | 2016-09-23 | 2018-08-07 | Apple Inc. | Intelligent automated assistant |
US10553215B2 (en) | 2016-09-23 | 2020-02-04 | Apple Inc. | Intelligent automated assistant |
US11281993B2 (en) | 2016-12-05 | 2022-03-22 | Apple Inc. | Model and ensemble compression for metric learning |
US10593346B2 (en) | 2016-12-22 | 2020-03-17 | Apple Inc. | Rank-reduced token representation for automatic speech recognition |
US11656884B2 (en) | 2017-01-09 | 2023-05-23 | Apple Inc. | Application integration with a digital assistant |
US12260234B2 (en) | 2017-01-09 | 2025-03-25 | Apple Inc. | Application integration with a digital assistant |
US11204787B2 (en) | 2017-01-09 | 2021-12-21 | Apple Inc. | Application integration with a digital assistant |
US10332518B2 (en) | 2017-05-09 | 2019-06-25 | Apple Inc. | User interface for correcting recognition errors |
US10417266B2 (en) | 2017-05-09 | 2019-09-17 | Apple Inc. | Context-aware ranking of intelligent response suggestions |
US10741181B2 (en) | 2017-05-09 | 2020-08-11 | Apple Inc. | User interface for correcting recognition errors |
US10847142B2 (en) | 2017-05-11 | 2020-11-24 | Apple Inc. | Maintaining privacy of personal information |
US10755703B2 (en) | 2017-05-11 | 2020-08-25 | Apple Inc. | Offline personal assistant |
US11599331B2 (en) | 2017-05-11 | 2023-03-07 | Apple Inc. | Maintaining privacy of personal information |
US10726832B2 (en) | 2017-05-11 | 2020-07-28 | Apple Inc. | Maintaining privacy of personal information |
US11467802B2 (en) | 2017-05-11 | 2022-10-11 | Apple Inc. | Maintaining privacy of personal information |
US10395654B2 (en) | 2017-05-11 | 2019-08-27 | Apple Inc. | Text normalization based on a data-driven learning network |
US11301477B2 (en) | 2017-05-12 | 2022-04-12 | Apple Inc. | Feedback analysis of a digital assistant |
US10410637B2 (en) | 2017-05-12 | 2019-09-10 | Apple Inc. | User-specific acoustic models |
US11405466B2 (en) | 2017-05-12 | 2022-08-02 | Apple Inc. | Synchronization and task delegation of a digital assistant |
US11837237B2 (en) | 2017-05-12 | 2023-12-05 | Apple Inc. | User-specific acoustic models |
US10789945B2 (en) | 2017-05-12 | 2020-09-29 | Apple Inc. | Low-latency intelligent automated assistant |
US10791176B2 (en) | 2017-05-12 | 2020-09-29 | Apple Inc. | Synchronization and task delegation of a digital assistant |
US11862151B2 (en) | 2017-05-12 | 2024-01-02 | Apple Inc. | Low-latency intelligent automated assistant |
US11580990B2 (en) | 2017-05-12 | 2023-02-14 | Apple Inc. | User-specific acoustic models |
US11380310B2 (en) | 2017-05-12 | 2022-07-05 | Apple Inc. | Low-latency intelligent automated assistant |
US11538469B2 (en) | 2017-05-12 | 2022-12-27 | Apple Inc. | Low-latency intelligent automated assistant |
US10810274B2 (en) | 2017-05-15 | 2020-10-20 | Apple Inc. | Optimizing dialogue policy decisions for digital assistants using implicit feedback |
US10482874B2 (en) | 2017-05-15 | 2019-11-19 | Apple Inc. | Hierarchical belief states for digital assistants |
US12014118B2 (en) | 2017-05-15 | 2024-06-18 | Apple Inc. | Multi-modal interfaces having selection disambiguation and text modification capability |
US10748546B2 (en) | 2017-05-16 | 2020-08-18 | Apple Inc. | Digital assistant services based on device capabilities |
US10403278B2 (en) | 2017-05-16 | 2019-09-03 | Apple Inc. | Methods and systems for phonetic matching in digital assistant services |
US11675829B2 (en) | 2017-05-16 | 2023-06-13 | Apple Inc. | Intelligent automated assistant for media exploration |
US11532306B2 (en) | 2017-05-16 | 2022-12-20 | Apple Inc. | Detecting a trigger of a digital assistant |
US10303715B2 (en) | 2017-05-16 | 2019-05-28 | Apple Inc. | Intelligent automated assistant for media exploration |
US12026197B2 (en) | 2017-05-16 | 2024-07-02 | Apple Inc. | Intelligent automated assistant for media exploration |
US10909171B2 (en) | 2017-05-16 | 2021-02-02 | Apple Inc. | Intelligent automated assistant for media exploration |
US11217255B2 (en) | 2017-05-16 | 2022-01-04 | Apple Inc. | Far-field extension for digital assistant services |
US10311144B2 (en) | 2017-05-16 | 2019-06-04 | Apple Inc. | Emoji word sense disambiguation |
US12254887B2 (en) | 2017-05-16 | 2025-03-18 | Apple Inc. | Far-field extension of digital assistant services for providing a notification of an event to a user |
US10657328B2 (en) | 2017-06-02 | 2020-05-19 | Apple Inc. | Multi-task recurrent neural network architecture for efficient morphology handling in neural language modeling |
US10445429B2 (en) | 2017-09-21 | 2019-10-15 | Apple Inc. | Natural language understanding using vocabularies with compressed serialized tries |
US10755051B2 (en) | 2017-09-29 | 2020-08-25 | Apple Inc. | Rule-based natural language processing |
US10636424B2 (en) | 2017-11-30 | 2020-04-28 | Apple Inc. | Multi-turn canned dialog |
US10733982B2 (en) | 2018-01-08 | 2020-08-04 | Apple Inc. | Multi-directional dialog |
US10733375B2 (en) | 2018-01-31 | 2020-08-04 | Apple Inc. | Knowledge-based framework for improving natural language understanding |
US10789959B2 (en) | 2018-03-02 | 2020-09-29 | Apple Inc. | Training speaker recognition models for digital assistants |
US10592604B2 (en) | 2018-03-12 | 2020-03-17 | Apple Inc. | Inverse text normalization for automatic speech recognition |
US11710482B2 (en) | 2018-03-26 | 2023-07-25 | Apple Inc. | Natural assistant interaction |
US10818288B2 (en) | 2018-03-26 | 2020-10-27 | Apple Inc. | Natural assistant interaction |
US12211502B2 (en) | 2018-03-26 | 2025-01-28 | Apple Inc. | Natural assistant interaction |
US10909331B2 (en) | 2018-03-30 | 2021-02-02 | Apple Inc. | Implicit identification of translation payload with neural machine translation |
US11169616B2 (en) | 2018-05-07 | 2021-11-09 | Apple Inc. | Raise to speak |
US11907436B2 (en) | 2018-05-07 | 2024-02-20 | Apple Inc. | Raise to speak |
US11900923B2 (en) | 2018-05-07 | 2024-02-13 | Apple Inc. | Intelligent automated assistant for delivering content from user experiences |
US11854539B2 (en) | 2018-05-07 | 2023-12-26 | Apple Inc. | Intelligent automated assistant for delivering content from user experiences |
US10928918B2 (en) | 2018-05-07 | 2021-02-23 | Apple Inc. | Raise to speak |
US11145294B2 (en) | 2018-05-07 | 2021-10-12 | Apple Inc. | Intelligent automated assistant for delivering content from user experiences |
US11487364B2 (en) | 2018-05-07 | 2022-11-01 | Apple Inc. | Raise to speak |
US10984780B2 (en) | 2018-05-21 | 2021-04-20 | Apple Inc. | Global semantic word embeddings using bi-directional recurrent neural networks |
US10720160B2 (en) | 2018-06-01 | 2020-07-21 | Apple Inc. | Voice interaction at a primary device to access call functionality of a companion device |
US10984798B2 (en) | 2018-06-01 | 2021-04-20 | Apple Inc. | Voice interaction at a primary device to access call functionality of a companion device |
US10403283B1 (en) | 2018-06-01 | 2019-09-03 | Apple Inc. | Voice interaction at a primary device to access call functionality of a companion device |
US12061752B2 (en) | 2018-06-01 | 2024-08-13 | Apple Inc. | Attention aware virtual assistant dismissal |
US10892996B2 (en) | 2018-06-01 | 2021-01-12 | Apple Inc. | Variable latency device coordination |
US12067985B2 (en) | 2018-06-01 | 2024-08-20 | Apple Inc. | Virtual assistant operations in multi-device environments |
US11009970B2 (en) | 2018-06-01 | 2021-05-18 | Apple Inc. | Attention aware virtual assistant dismissal |
US11431642B2 (en) | 2018-06-01 | 2022-08-30 | Apple Inc. | Variable latency device coordination |
US11630525B2 (en) | 2018-06-01 | 2023-04-18 | Apple Inc. | Attention aware virtual assistant dismissal |
US10684703B2 (en) | 2018-06-01 | 2020-06-16 | Apple Inc. | Attention aware virtual assistant dismissal |
US11386266B2 (en) | 2018-06-01 | 2022-07-12 | Apple Inc. | Text correction |
US11360577B2 (en) | 2018-06-01 | 2022-06-14 | Apple Inc. | Attention aware virtual assistant dismissal |
US11495218B2 (en) | 2018-06-01 | 2022-11-08 | Apple Inc. | Virtual assistant operation in multi-device environments |
US12080287B2 (en) | 2018-06-01 | 2024-09-03 | Apple Inc. | Voice interaction at a primary device to access call functionality of a companion device |
US10504518B1 (en) | 2018-06-03 | 2019-12-10 | Apple Inc. | Accelerated task performance |
US10496705B1 (en) | 2018-06-03 | 2019-12-03 | Apple Inc. | Accelerated task performance |
US10944859B2 (en) | 2018-06-03 | 2021-03-09 | Apple Inc. | Accelerated task performance |
US11010561B2 (en) | 2018-09-27 | 2021-05-18 | Apple Inc. | Sentiment prediction from textual data |
US11893992B2 (en) | 2018-09-28 | 2024-02-06 | Apple Inc. | Multi-modal inputs for voice commands |
US11170166B2 (en) | 2018-09-28 | 2021-11-09 | Apple Inc. | Neural typographical error modeling via generative adversarial networks |
US10839159B2 (en) | 2018-09-28 | 2020-11-17 | Apple Inc. | Named entity normalization in a spoken dialog system |
US11462215B2 (en) | 2018-09-28 | 2022-10-04 | Apple Inc. | Multi-modal inputs for voice commands |
US11475898B2 (en) | 2018-10-26 | 2022-10-18 | Apple Inc. | Low-latency multi-speaker speech recognition |
US11638059B2 (en) | 2019-01-04 | 2023-04-25 | Apple Inc. | Content playback on multiple devices |
US11783815B2 (en) | 2019-03-18 | 2023-10-10 | Apple Inc. | Multimodality in digital assistant systems |
US11348573B2 (en) | 2019-03-18 | 2022-05-31 | Apple Inc. | Multimodality in digital assistant systems |
US12136419B2 (en) | 2019-03-18 | 2024-11-05 | Apple Inc. | Multimodality in digital assistant systems |
US11475884B2 (en) | 2019-05-06 | 2022-10-18 | Apple Inc. | Reducing digital assistant latency when a language is incorrectly determined |
US11217251B2 (en) | 2019-05-06 | 2022-01-04 | Apple Inc. | Spoken notifications |
US12216894B2 (en) | 2019-05-06 | 2025-02-04 | Apple Inc. | User configurable task triggers |
US11307752B2 (en) | 2019-05-06 | 2022-04-19 | Apple Inc. | User configurable task triggers |
US11675491B2 (en) | 2019-05-06 | 2023-06-13 | Apple Inc. | User configurable task triggers |
US11705130B2 (en) | 2019-05-06 | 2023-07-18 | Apple Inc. | Spoken notifications |
US11423908B2 (en) | 2019-05-06 | 2022-08-23 | Apple Inc. | Interpreting spoken requests |
US12154571B2 (en) | 2019-05-06 | 2024-11-26 | Apple Inc. | Spoken notifications |
US11888791B2 (en) | 2019-05-21 | 2024-01-30 | Apple Inc. | Providing message response suggestions |
US11140099B2 (en) | 2019-05-21 | 2021-10-05 | Apple Inc. | Providing message response suggestions |
US11657813B2 (en) | 2019-05-31 | 2023-05-23 | Apple Inc. | Voice identification in digital assistant systems |
US11360739B2 (en) | 2019-05-31 | 2022-06-14 | Apple Inc. | User activity shortcut suggestions |
US11289073B2 (en) | 2019-05-31 | 2022-03-29 | Apple Inc. | Device text to speech |
US11237797B2 (en) | 2019-05-31 | 2022-02-01 | Apple Inc. | User activity shortcut suggestions |
US11496600B2 (en) | 2019-05-31 | 2022-11-08 | Apple Inc. | Remote execution of machine-learned models |
US11360641B2 (en) | 2019-06-01 | 2022-06-14 | Apple Inc. | Increasing the relevance of new available information |
US11790914B2 (en) | 2019-06-01 | 2023-10-17 | Apple Inc. | Methods and user interfaces for voice-based control of electronic devices |
US11488406B2 (en) | 2019-09-25 | 2022-11-01 | Apple Inc. | Text detection using global geometry estimators |
US11765209B2 (en) | 2020-05-11 | 2023-09-19 | Apple Inc. | Digital assistant hardware abstraction |
US12197712B2 (en) | 2020-05-11 | 2025-01-14 | Apple Inc. | Providing relevant data items based on context |
US11914848B2 (en) | 2020-05-11 | 2024-02-27 | Apple Inc. | Providing relevant data items based on context |
US11924254B2 (en) | 2020-05-11 | 2024-03-05 | Apple Inc. | Digital assistant hardware abstraction |
US11838734B2 (en) | 2020-07-20 | 2023-12-05 | Apple Inc. | Multi-device audio adjustment coordination |
US11696060B2 (en) | 2020-07-21 | 2023-07-04 | Apple Inc. | User identification using headphones |
US12219314B2 (en) | 2020-07-21 | 2025-02-04 | Apple Inc. | User identification using headphones |
US11750962B2 (en) | 2020-07-21 | 2023-09-05 | Apple Inc. | User identification using headphones |
US12277954B2 (en) | 2024-04-16 | 2025-04-15 | Apple Inc. | Voice trigger for a digital assistant |
Also Published As
Publication number | Publication date |
---|---|
CN105474170A (en) | 2016-04-06 |
US20160203125A1 (en) | 2016-07-14 |
EP3011472A2 (en) | 2016-04-27 |
US9311298B2 (en) | 2016-04-12 |
US20140379326A1 (en) | 2014-12-25 |
KR20160021787A (en) | 2016-02-26 |
CN110263327B (en) | 2023-10-10 |
CN105474170B (en) | 2019-06-11 |
KR102406236B1 (en) | 2022-06-07 |
US10572602B2 (en) | 2020-02-25 |
US9697200B2 (en) | 2017-07-04 |
US20170255612A1 (en) | 2017-09-07 |
CN110263327A (en) | 2019-09-20 |
WO2014204659A3 (en) | 2015-07-23 |
KR20210114562A (en) | 2021-09-23 |
KR102303483B1 (en) | 2021-09-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10572602B2 (en) | Building conversational understanding systems using a toolset | |
AU2019208255B2 (en) | Environmentally aware dialog policies and response generation | |
US9292492B2 (en) | Scaling statistical language understanding systems across domains and intents | |
US9875237B2 (en) | Using human perception in building language understanding models | |
US10339916B2 (en) | Generation and application of universal hypothesis ranking model | |
US9412363B2 (en) | Model based approach for on-screen item selection and disambiguation | |
US20140236575A1 (en) | Exploiting the semantic web for unsupervised natural language semantic parsing | |
US20140379323A1 (en) | Active learning using different knowledge sources | |
US20140236570A1 (en) | Exploiting the semantic web for unsupervised spoken language understanding | |
KR20170099917A (en) | Discriminating ambiguous expressions to enhance user experience | |
US20140350931A1 (en) | Language model trained using predicted queries from statistical machine translation | |
US8996377B2 (en) | Blending recorded speech with text-to-speech output for specific domains |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
WWE | Wipo information: entry into national phase |
Ref document number: 201480035400.4 Country of ref document: CN |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 14736143 Country of ref document: EP Kind code of ref document: A2 |
|
DPE1 | Request for preliminary examination filed after expiration of 19th month from priority date (pct application filed from 20040101) | ||
WWE | Wipo information: entry into national phase |
Ref document number: 2014736143 Country of ref document: EP |
|
ENP | Entry into the national phase |
Ref document number: 20157035936 Country of ref document: KR Kind code of ref document: A |