Interactions between computer-controlled animated or robotic characters and people are becoming more common. However, to facilitate such interactions, it is necessary to identify when a participant in an interactive game, for example, is speaking to the character versus simply communicating to another participant. Current approaches have focused on the interactions with groups of adults. However, interactions commonly take place between computer-controlled animated or robotic characters and small groups of children. Current approaches based on adult data do not effectively translate to children, particularly young children, due to their limited mastery of language and social conventions, their limited knowledge of the world, cognitive processing speed, consistent use of gestures, as well as their inability to stand still, for example. Furthermore, current approaches based on data from modeling adult tasks, such as meetings around a table or dyads around an information kiosk, do not effectively translate to multi-participant game environments.
The present application is directed to addressee identification of speech in small groups of children and adults, substantially as shown in and/or described in connection with at least one of the figures, and as set forth more completely in the claims.
The following description contains specific information pertaining to implementations in the present disclosure. One skilled in the art will recognize that the present disclosure may be implemented in a manner different from that specifically discussed herein. The drawings in the present application and their accompanying detailed description are directed to merely exemplary implementations. Unless noted otherwise, like or corresponding elements among the figures may be indicated by like or corresponding reference numerals. Moreover, the drawings and illustrations in the present application are generally not to scale, and are not intended to correspond to actual relative dimensions.
Within system 100, participants 120, 122, 124, 126 and 128 may interact with automated character 110 through greetings, responses to yes/no questions, or referring phrases choosing from several objects, which may be presented to the participants on a display or spoken to the participants by automated character 110, for example. The participants may interact with the automated character through gestures such as head shake yes, head shake no, pointing gestures or emphasis gestures, for example, and through head movements such as head turn away, head turn back or head incline, for example. Such head movements may be determined with respect to automated character 110 or, in the alternative, may be determined with respect to another one of the participants, for example. Audio and video data of the participants, captured by one or more of microphones 132a and 132b and one or more of video capture devices 134a and 134b, may be utilized to recognize when speech from one of the participants is directed to an automated character, and utilize that speech to advance a game or presentation within the system, for example.
The operation of the system disclosed in
In the present application, the task of automatically identifying whether speech from a participant is directed to an automated character is approached as a non-probabilistic binary classification task. That is, the methods disclosed herein attempt to definitively classify speech as either character-directed or non-character-directed speech, rather than assigning probabilities to the likelihood of a segment of speech being properly classified as one or the other. The present application contemplates a machine learning approach utilizing a support vector machine (SVM), for example. However, the present application is not limited to a SVM approach, but may encompass any other suitable non-probabilistic approach.
Action 210 of flowchart 200 includes defining a plurality of time intervals. In each implementation of the present application, each participant's participation is divided into a plurality of equal-duration time intervals. Such division is illustrated by
A first function evaluation may then be applied to each of a plurality of participants during each of the time intervals in succession. Action 220 of flowchart 200 includes applying a first function evaluation. According to the implementation shown in
Action 410 of diagram 400 includes computing values for a predetermined set of features for each of the participants during a particular time interval. Depending on the game environment or nature of a presentation with which participants interact, the specific features within a set of features, which may be optimal for assignee identification of speech, may not always be the same. Thus, different implementations may include predetermined feature sets having one or more of the exemplary features determined by actions 420 through 460. However, the present inventive concepts are not limited to the features of actions 420 through 460, but may include any additional features which may be useful for addressee identification of speech, for example.
Action 420 of diagram 400 includes a determination of whether the particular participant, for which the set of features is being determined, is speaking during the particular time interval. According to the implementation shown in
Whether an automated character has generated speech or sound effects which would prompt a participant to respond during a particular time interval, may have an effect on whether participant speech during the interval is directed to the automated character. Action 430 of diagram 400 includes determining whether the automated character prompted for a response from the plurality of participants during the particular time interval. Such prompts may include speech or sound effects from the automated character, for example. According to the implementation shown in
The gestures or head movements of a particular participant may also have an effect on whether participant speech is directed to the automated character rather than another participant, for example. Action 440 of diagram 400 includes determining whether gestures or head movements of the particular participant, for which the set of features is being determined, are present during the particular time interval. According to the implementation shown in
Continuing with action 450 of diagram 400, action 450 includes determining a pitch of the participant speech and a volume of the participant speech, each averaged over the particular time interval. According to the implementation shown in
Action 460 of diagram 400 includes determining whether the participant speech includes one or more discourse markers, utilizing speech recognition. The discourse markers may include task-independent words such as “um”, “ok”, “who”, “what”, “when”, “where”, “why” and words having equivalent meanings in English. For example, and without limitation, the word “urn” may also include words such as “ah”, “hmm” and “huh” while the word “ok” may also include words such as “yes”, “yeah” and “uh huh”. Such words and their variations may additionally apply to non-English languages and dialects. According to the implementation shown in
Where an implementation utilizes the set of features created by actions 420 through 450 of diagram 400, for example, addressee identification of participant speech during a particular time interval may be made independent of speech recognition while focusing on only that particular time interval of each of the participants' behavior, lasting for example, 500 milliseconds. Where an implementation utilizes the set of features created by actions 420 through 460 of diagram 400, for example, consideration of the effect of accurate speech recognition over a small, task-independent vocabulary on addressee identification of participant speech may also be incorporated.
Continuing with action 470 of diagram 400, action 470 includes assigning a first addressing status to each participant during the particular time interval, based on the set of features for each of the participants determined during the particular time interval. Thus, the implementations discussed thus far utilize only the first function evaluation, which analyzes only the particular time interval for which the classification is being made, to classify and identify each participant as addressing speech to an automated character during that particular time interval.
However, each of the above mentioned determinations may be more useful when considered over several time intervals. Thus, an alternative implementation builds on the implementations discussed above by applying a second function evaluation, in addition to the first function evaluation, within the method for assignee identification of speech. The second function evaluation may be configured to assign a second addressing status to a particular time interval utilizing results of the first function evaluation for that particular time interval and for one or more additional contiguous time intervals.
The arrangement of the one or more additional contiguous time intervals may vary according to the needs of a particular application. For example, in one specific application the second function evaluation may utilize results from the time interval being classified as well as one immediately prior time interval and two immediately following time intervals. In another specific application, the second function evaluation may utilize results from the time interval being classified as well as one immediately prior time interval and one immediately following time interval.
Referring back to
Such an implementation is further illustrated by
Thus, according to the this implementation, the classification of a particular time interval as containing participant speech addressed to an automated character or not may be delayed from real-time according to the number of time intervals immediately following the particular time interval which are utilized by the second function evaluation.
Once the first and second function evaluations have been applied, each participant may be classified as addressing speech to an automated character or not addressing speech to the automated character during each time interval. Action 240 of flowchart 200 includes classifying each of the plurality of participants as addressing speech to an automated character or not addressing speech to an automated character during each of the plurality of time intervals. According to the implementation shown in
From the above description it is manifest that various techniques can be used for implementing the concepts described in the present application without departing from the scope of those concepts. Moreover, while the concepts have been described with specific reference to certain implementations, a person of ordinary skill in the art would recognize that changes can be made in form and detail without departing from the spirit and the scope of those concepts. As such, the described implementations are to be considered in all respects as illustrative and not restrictive. It should also be understood that the present application is not limited to the particular implementations described herein, but many rearrangements, modifications, and substitutions are possible without departing from the scope of the present disclosure.