1. Field of the Invention
The present invention generally relates to a robot that corrects an output voice based on a bearing of a head unit of the robot, and a method and a program of controlling the robot.
Priority is claimed on Japanese Patent Application No. 2010-056265, filed Mar. 12, 2010, the content of which is incorporated herein by reference.
2. Description of the Related Art
All patents, patent applications, patent publications, scientific articles, and the like, which will hereinafter be cited or identified in the present application, will hereby be incorporated by reference in their entirety in order to describe more fully the state of the art to which the present invention pertains.
In recent years, there has been performed an art in which information other than a language such as a prosody and emotion information is attached to an output voice of a communication robot. By attaching the prosody or the emotion information to the output voice, the meaning of the output voice can be transmitted more accurately. Japanese Unexamined Patent Application, First Publication No. 2002-23775 discloses a method of modeling a vocal tract of a man so as to increase the expressive power in a voice synthesis.
In the prior art described above, the output voice is not changed even if the bearing of the communication robot, especially in the direction of the face of the communication robot, is changed, which can seem strange to people.
A robot may include a driving control unit configured to control a driving of a movable unit that is connected movably to a body unit, a voice generating unit configured to generate a voice, and a voice output unit configured to output the voice, which has been generated by the voice generating unit. The voice generating unit may correct the voice, which is generated, based on a bearing of the movable unit, which is controlled by the driving control unit, to the body unit.
The movable unit may include a head unit, and the voice generating unit may correct the voice, which is generated using a vocal tract filter, based on the bearing in a direction of a pitch axis of the head unit.
The voice generating unit may use the vocal tract filter, which amplifies a frequency band of a signal of the voice, a sound pressure level is based on a pitch angle that corresponds to the bearing of the head unit in the frequency band. The voice generating unit may amplify the frequency band, which is based on the pitch angle, of the signal of the voice, which is generated, using the vocal tract filter.
The movable unit may include a head unit. The voice generating unit may correct a left-right ratio of an output level of the voice, which is generated, based on the bearing in a direction of a yaw axis of the head unit.
The voice generating unit may correct a left-right ratio of an output level of the voice, which is generated, based on the bearing in a direction of a yaw axis of the head unit.
A method of controlling a robot may include controlling of a driving of a movable unit that is connected movably to a body unit, generating of a voice, and outputting of the voice, which has been generated. The generating of the voice may include correcting of the voice based on a bearing of the movable unit to the body unit.
A program may control a robot including a movable unit that is connected movably to a body unit, the robot generating and outputting a voice. The program may execute a driving control step of controlling a driving of the movable unit, a voice generating step of generating the voice, and a voice output step of outputting the voice, which has been generated by the voice generating step. The voice generating step may correct the voice, which is generated, based on a bearing of the movable unit, which is controlled by the driving control step, to the body unit.
The above features and advantages of the present invention will be more apparent from the following description of certain preferred embodiments taken in conjunction with the accompanying drawings, in which:
The present invention provides an art by which a natural sounding voice, which does not seem strange to people, can be output based on a bearing of a robot.
In the robot of the present invention, a voice output unit does not output a voice that has been generated by a voice generating unit without change. The voice that has been generated by the voice generating unit is corrected based on a bearing of a movable unit to be output from the voice output unit. Therefore, the robot can output a natural sounding voice, which does not seem strange to people, based on the bearing of the movable unit without moving a position and an angle of a speaker based on the bearing of the movable unit.
In the robot of the present invention, the voice is varied based on the bearing of a head unit in a vertical direction by imitating a variation of a voice by a man. Therefore, the robot can output a more natural sounding voice.
In the robot of the present invention, a frequency band that depends on a variation of a pitch angle is changed. Therefore, the robot can output the voice effectively.
In the robot of the present invention, the voice is varied based on the bearing of the head unit in a horizontal direction. Therefore, the robot can output a more natural sounding voice.
By using a method and program of the present invention, an effect similar to the robot of the present invention can be acquired.
The present invention will be now described herein with reference to illustrative embodiments. Those skilled in the art will recognize that many alternative embodiments can be accomplished using the teaching of the present invention and that the present invention is not limited to the embodiments illustrated for explanatory purpose.
The head control unit 120 is disposed in the head unit 42 or at an upper portion of the body unit 41. The head control unit 120 the bearing (a rotation movement) of the head unit 42 around the pitch axis, which is in a vertical plane, based on a control signal from the control unit 100. Also, the head control unit 120 controls the bearing (a rotation movement) of the head unit 42 around the yaw axis, which is in a horizontal plane, based on the control signal from the control unit 100. By this control, a bearing of the head unit 42 to the body unit 41 can be changed in the direction of the pitch axis and in the direction of the yaw axis. Then, the head unit 42 can be shaken from side to side and up and down.
The leg control unit 150L is disposed in the leg unit 43L. The leg control unit 150R is disposed in the leg unit 43R. The leg control unit 150L and the leg control unit 150R control an operation such as a two-legged walking based on the control signal from the control unit 100. The arm control unit 130L is disposed in the arm unit 44L. The arm control unit 130R is disposed in the arm unit 44R. The arm control unit 130L and the arm control unit 130R control an operation of the arm unit 44L and the arm unit 44R during the two-legged walking based on the control signal from the control unit 100.
The control unit 100 is disposed in the storage unit 45. The control unit 100 outputs the control signal to the head control unit 120, the leg control unit 150L, the leg control unit 150R, the arm control unit 130L, and the arm control unit 130R, and controls the operation of the head unit 42, the leg unit 43L, the leg unit 43R, the arm unit 44L, and the arm unit 44R. The control unit 100 outputs information, which represents the bearing of the head unit 42 to the body unit 41, to the voice generating unit 110. The information that represents the bearing of the head unit 42 to the body unit 41 is referred to as head unit bearing information.
If the control unit 100 outputs the information, which represents the bearing of the head unit 42 to the body unit 41 after a change of the bearing or a control by the control unit 100, to the head control unit 120 as control information, then the control information is output to the voice generating unit 110 as the head unit bearing information. If the control unit 100 outputs the information, which represents a variation of the bearing of the head unit 42 to the body unit 41 between the present condition and the condition after the change of the bearing or the control by the control unit 100, to the head control unit 120 as control information, then the bearing of the head unit 42 to the body unit 41 after the change of the bearing or the control by the control unit 100 is calculated, and the result of the calculation is output to the voice generating unit 110 as the head unit bearing information.
The voice generating unit 110 is disposed in the storage unit 45 and includes a voice signal generating unit 112 and a voice signal correction unit 114. The voice signal generating unit 112 generates a voice signal corresponding to a prescribed voice. The voice signal generating unit 112 outputs the voice signal, which has been generated, to the voice signal correction unit 114. The prescribed voice is such as the voice corresponding to a language that is designated from outside, for example, by an operator of the robot 4, the voice corresponding to a result of a prescribed determination process that is selected based on an order from outside, and the voice corresponding to a detection result of various sensors that the robot 4 includes, for example, the sensor for detecting obstacles. The robot 4 can output the voice while moving the head unit 42.
The voice signal correction unit 114 receives the voice signal from the voice signal generating unit 112. The voice signal correction unit 114 receives the head unit bearing information from the control unit 100. The voice signal correction unit 114 corrects the voice signal, which has been received from the voice signal generating unit 112, based on the head unit bearing information, which has been received from the control unit 100.
Specifically, the voice signal correction unit 114 receives the head unit bearing information that includes an angle showing the bearing of the head unit 42 in the direction of the pitch axis and an angle showing the bearing of the head unit 42 in the direction of the yaw axis. Concerning the bearing of the head unit 42 in the direction of the pitch axis, the voice signal correction unit 114 corrects the voice signal, which has been received from the voice signal generating unit 112, by using a vocal tract filter that is based on a vocal tract model. If the bearing of the head unit 42 varies in the direction of the pitch axis, then a shape of the vocal tract varies and a spectral envelope of the voice signal varies. Concerning the bearing of the head unit 42 in the direction of the yaw axis, the voice signal correction unit 114 corrects a left-right ratio of an output level of the voice signal that is output to the voice output unit 140L and the voice output unit 140R. If the bearing of the head unit 42 varies in the direction of the yaw axis, then the shape of the vocal tract does not change and adjusting the left-right ratio of the output level of the voice signal is sufficient. The vocal tract filter based on the vocal tract model, the left-right ratio of the output level of the voice signal, the correction based on the bearing of the head unit 42 in the direction of the pitch axis, and the correction based on the bearing of the head unit 42 in the direction of the yaw axis will be described below.
The voice signal correction unit 114 outputs the voice signal that has been corrected or the voice signal from the voice signal generating unit 112 based on the head unit bearing information to the voice output unit 140L and the voice output unit 140R.
The voice output unit 140L and the voice output unit 140R are disposed in the body unit 41, as described above. The voice output unit 140L and the voice output unit 140R receives the voice signal that has been generated by the voice generating unit 110 to output a voice to the exterior. The voice signal has been generated by the voice signal generating unit 112 or corrected by the voice signal correction unit 114.
Details of the voice signal correction unit 114 will be described below.
Description of the Vocal Tract Filter Based on the Vocal Tract Model
The vocal tract filter is modeled as H(θp), while θp is an angle of the head unit 42 in the direction of the pitch axis. In the preferred embodiment of the present invention, the vocal tract filter H(θp) is modeled by examining the voice of a man. Specifically, the head of an examinee is varied (by 10 degrees) between 50 degrees in a downward direction and 50 degrees in an upward direction, and each voice corresponding to each pitch angle θp is recorded having the same volume. The recording is performed in an anechoic room by using a close-talking microphone. As a result, the vocal tract filter H(θp) is modeled. More specifically, a sweep sound for 10 seconds that is made by producing a vowel “a” and has a basic frequency between 201 Hz and 523 Hz is recorded. Next, the voice signal of the recorded voice is analyzed by using one-third octave-band analysis, and a sound pressure level ratio is calculated by using a point of each frequency band which pitch angle is 0 degrees as a reference point.
The frequency band of the voice signal that is corrected based on the pitch angle θp is the frequency band in which the sound pressure level varies significantly based on the variation of the pitch angle θp. Specifically, three frequency bands i.e. 500 Hz, between 800 Hz and 1,000 Hz, and between 2,500 Hz and 4,000 Hz are used in the frequency bands. In these three frequency bands, the sound pressure level varies significantly based on the variation of the pitch angle θp as illustrated in
The horizontal axis of
Description of the Left-Right Ratio of the Output Level of the Voice Signal
The correction of the left-right ratio of the output level of the voice signal based on the yaw angle θy is performed by using a model illustrated in
The measurement value illustrated in
Correction Based on the Bearing in the Direction of the Pitch Axis and the Yaw Axis
The voice signal correction unit 114 corrects the voice signal, which is received from the voice signal generating unit 112, that is an input voice signal x(t) based on the pitch angle θp of the head unit 42 and then based on the yaw angle θy, of the head unit 42.
First, for correction based on the pitch angle θp, the voice signal correction unit 114 resolves the input voice signal x(t) into a θp-dependent element xi(t), which depends on the pitch angle θp, and a θp-independent element xNULL(t), which does not depend on the pitch angle θp. Here, ‘i’ of the θp-dependent element xi(t) represents an index of the frequency band to be corrected. The input voice signal x1(t) is 500 Hz, the input voice signal x2(t) is between 800 Hz and 1,000 Hz, and the input voice signal x3(t) is between 2,500 Hz and 4,000 Hz.
Specifically, the voice signal correction unit 114 calculates the θp-dependent element xi(t) based on the equation (1) and calculates the θp-independent element xNULL(t) based on the equation (2).
xi(t)=(x*hi)(t) (1)
xNULL(t)=(x*hNULL)(t) (2)
Here, * represents a convolution operation. In the equation (1), hi represents a band pass filter that transmits the θp-dependent element xi(t) that includes the frequency bands of 500 Hz, between 800 Hz and 1,000 Hz, and between 2,500 Hz and 4,000 Hz. Also xNULL(t) is equal to the input voice signal x(t) minus the θp-dependent element xi(t). The gain of the frequency response corresponding to hNULL is zero at the frequency of 500 Hz, between 800 Hz and 1,000 Hz, and between 2,500 Hz and 4,000 Hz. The gain of the frequency response corresponding to hNULL is 1 at the center frequency of one-third octave-band except the frequency of 500 Hz, between 800 Hz and 1,000 Hz, and between 2,500 Hz and 4,000 Hz.
Next, concerning the θp-dependent element xi(t), the voice signal correction unit 114 calculates a gain gpi(t) of the i-th frequency band at the pitch angle θp(t) based on the equation (3).
In the equation (3), the angle θm and the angle θm+1 are based on the pitch angle θp(t), which represents the bearing of the head unit 42 in the direction of the pitch axis, that are included in the head unit bearing information received from the control unit 100. Specifically, the angle θm and the angle θm+1 are calculated from the pitch angle θp(t) based on the equations (4) and (5).
θm+1=(└θp(t)/10┘+1)×10 (4)
θm=(└θp(t)/10┘)×10 (5)
Here, └ ┘ represents a floor function. For example, if θp(t)=35 degrees, then θm+1=40 degrees and the angle θm=30 degrees.
Concerning the θp-dependent element xi(t), the voice signal correction unit 114 linearly-interpolates and amplifies a spectral envelope model corresponding to the gain of each pitch angle θp(t) of
Next, the voice signal correction unit 114 amplifies the θp-dependent element xi(t) based on the equation (6).
Next, the voice signal correction unit 114 synthesizes the θp-dependent element xi(t) and the θp-independent element xNULL(t) based on the equation (7) to calculate a monaural signal xp that is corrected based on the pitch angle θp(t).
As described above, the voice signal correction unit 114 corrects the voice signal x(t), which has been generated by the voice signal generating unit 112, based on the pitch angle θp, which represents the bearing of the head unit 42 in the direction of the pitch axis, by using the vocal tract filter of the equations (1), (2), . . . and (7). The vocal tract filter is in the time domain and made of the vocal tract filter H(θp) that is represented in the frequency domain.
Next, the voice signal correction unit 114 generates a stereo signal xste from the monaural signal xp so as to correct the voice signal based on the yaw angle θy. The stereo signal xste includes a left channel signal xL(t) and a right channel signal xR(t).
Next, the voice signal correction unit 114 calculates a gain gPL(t:θy(t)) of the left channel signal xL(t) corresponding to the yaw angle θy based on the equation (8). That is, the voice signal correction unit 114 corrects the output level ratio between the left channel signal xL(t) and the right channel signal xR(t) based on the bearing of the head unit 42 in the direction of the yaw axis.
In the equation (8), the angle θn and the angle θn+1 are based on the yaw angle θy(t) that represents the bearing of the head unit 42 in the direction of the yaw axis which is included in the head unit bearing information received from the control unit 100. Specifically, the angle θn and the angle θn+1 are calculated by the equations (9) and (10) based on the yaw angle θy(t).
θn+1=(└θy(t)/10┘+1)×10 (9)
θn=(└θy(t)/10┘)×10 (10)
Here, └ ┘ represents the floor function. For example, if θy(t)=35 degrees, then θn+1=40 degrees and the angle θn=30 degrees.
The gain of the left channel signal xL(t) and the gain of the right channel signal xR(t) are symmetric as shown in the equation (11). Therefore, the voice signal correction unit 114 calculates a gain gPR(t:θy(t)) of the right channel signal xR(t) corresponding to the yaw angle θy(t).
gRy(t:θy(t))=gLy(t:−θy(t)) (11)
That is, the voice signal correction unit 114 linearly-interpolates and amplifies a spectral envelope model corresponding to the gain of each yaw angle θy(t) of
The voice signal correction unit 114 amplifies the left channel signal xL(t) based on the equation (12) to generate a left channel output voice signal x′L(t), and outputs the left channel output voice signal x′L(t) to the voice output unit 140L. The voice signal correction unit 114 amplifies the right channel signal xR(t) based on the equation (13) to generate a right channel output voice signal x′R(t), and outputs the right channel output voice signal x′R(t) to the voice output unit 140R.
As described above, the voice signal correction unit 114 corrects the left channel signal xL(t) and the right channel signal xR(t) to generate the left channel output voice signal x′L(t) and the right channel output voice signal x′R(t) based on the yaw angle θy(t) that represents the bearing of the head unit 42 in the direction of the yaw axis. That is, the voice signal correction unit 114 corrects the output level ratio of the left channel signal xL(t) and the right channel signal xR(t).
As described above, in the preferred embodiment of the present invention, the voice generated by the voice generating unit is not output from the voice output unit as it is. The voice generated by the voice generating unit is corrected based on the bearing of the movable unit and then output from the voice output unit. Therefore, the robot can output a natural sounding voice, which does not seem strange to people, based on the bearing of the movable unit. The voice is varied by imitating the variation of the voice of a man. The voice is varied based on the bearing of the head unit 42 not only in the vertical direction but also in the horizontal direction. Therefore, the robot can output a more natural sounding voice.
The voice signal is corrected based on the bearing in the direction of the pitch axis by limiting the frequency of the correction target to a prescribed frequency based on an experimental result. Therefore, the amount of the calculation in performing the correction can be reduced effectively.
In the preferred embodiment of the present invention described above, the control unit 100 outputs the head unit bearing information to the voice signal correction unit 114. That is, the voice signal correction unit 114 receives the head unit bearing information from the control unit 100. The head unit bearing information represents the bearing of the head unit 42 to the body unit 41. The voice signal correction unit 114 refers to the head unit bearing information when correcting the voice signal. But the way of the voice signal correction unit 114 receiving the head unit bearing information is not limited to the above way. For example, the robot 1 may include a measurement unit, which is not illustrated in the figure, that measures the bearing of the head unit 42 to the body unit 41, and the voice signal correction unit 114 may use the measurement result of the measurement unit as the head unit bearing information.
In the preferred embodiment of the present invention described above, the voice signal correction unit 114 corrects the voice signal based on the head unit bearing information. However, the method of the voice signal correction unit 114 correcting the voice signal is not limited to the above described method. For example, the voice signal correction unit 114 may correct the voice signal based on information including the bearing of the leg unit 43L, the leg unit 43R, the arm unit 44L, and the arm unit 44R to the body unit 41.
A program that executes various processing of the robot 4 in accordance with the preferred embodiment of the present invention may be stored in a computer-readable recording medium. A computer system may read and execute the program that is stored in the recording medium to perform the various processing described above in accordance with the robot 4 of the preferred embodiment of the present invention. The computer system may include an OS or hardware such as peripheral device etc. Also, the computer system may employ a WWW (World Wide Web) system. With such an arrangement, the computer system includes a homepage providing circumstances or homepage display environment.
Further, the computer readable recording medium refers to a writable nonvolatile memory such as a flexible disk, a magneto-optical disk, a ROM, or a flash memory, a portable medium such as a CD-ROM, and a memory device such as a hard disk incorporated in a computer system.
In addition, the “computer readable recording medium” includes a medium storing a program for a predetermined time period, such as a volatile memory (for example, dynamic random access memory (DRAM)) incorporated in the computer system which becomes a server or a client in a case where the program is transmitted via a network such as the Internet, or a communication line such as a telephone line.
Further, the above-mentioned program may be transmitted from the computer system which stores the program in the memory device or the like via a transmission medium, or may be transmitted by a transmitted wave through the transmission medium to another computer system. In this case, the “transmission medium” for transmitting the program refers to a medium having a function for transmitting information like a network (communication network) such as the Internet, or a communication line (communication wire) such as a telephone line.
Further, the above-mentioned program may be a program for realizing part of the above-mentioned function. Moreover, there may be used a program that can realize the above-mentioned function by a combination of a program already recorded in the computer system, that is, a differential file (differential program).
In the above descriptions of the present invention, the bearing of the robot represents the attitude of the robot. The bearing of the movable unit is equal to the bearing of the robot.
As used herein, the following directional terms “forward, rearward, above, downward, vertical, horizontal, below, and transverse” as well as any other similar directional terms refer to those directions of an apparatus equipped with the present invention. Accordingly, these terms, as utilized to describe the present invention should be interpreted relative to an apparatus equipped with the present invention.
The term “configured” is used to describe a component, section or part of a device including hardware and/or software that is constructed and/or programmed to carry out the desired function.
Moreover, terms that are expressed as “means-plus function” in the claims should include any structure that can be utilized to carry out the function of that part of the present invention.
The terms of degree such as “substantially,” “about,” “nearly”, and “approximately” as used herein mean a reasonable amount of deviation of the modified term such that the end result is not significantly changed. For example, these terms can be construed as including a deviation of at least ±5 percents of the modified term if this deviation would not negate the meaning of the word it modifies.
While preferred embodiments of the invention have been described and illustrated above, it should be understood that these are exemplary of the invention and are not to be considered as limiting. Additions, omissions, substitutions, and other modifications can be made without departing from the scope of the present invention. Accordingly, the invention is not to be considered as being limited by the foregoing description, and is only limited by the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
2010-056265 | Mar 2010 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4820232 | Takahashi et al. | Apr 1989 | A |
20040127140 | Kelly et al. | Jul 2004 | A1 |
20040153212 | Profio et al. | Aug 2004 | A1 |
20050215170 | Poesch | Sep 2005 | A1 |
20060143006 | Asano | Jun 2006 | A1 |
20070150107 | Ogawa et al. | Jun 2007 | A1 |
Number | Date | Country |
---|---|---|
2002-23775 | Jan 2002 | JP |
2002085858 | Mar 2002 | JP |
2005-266671 | Sep 2005 | JP |
2006-136963 | Jun 2006 | JP |
2011167820 | Sep 2011 | JP |
2005076660 | Aug 2005 | WO |
Entry |
---|
Otsuka, Takuma, et al. “Voice-Awareness Control Consistent with Robot's Body Movements.” RSJ 2009, Sep. 15, 2009, pp. 1-4. |
Otsuka et al, “Voice Quality Manipulation for Humanoid Robots Consistent with their Head Movements,” 9th IEEE RAS International Conference on Human Robots, Dec. 7-10, 2009, Paris, France, pp. 405-410. |
Miwa et al, “Development of a New Human-like Head Robot WE-4,” Proceedings of the 2002 IEEE/RSJ Intl. Conference on Intelligent Robots and Systems, Oct. 2002, pp. 2443-2448. |
Japanese Notice of Allowance for Application No. 2010-056265, 8 pages, dated Sep. 17, 2013. |
Number | Date | Country | |
---|---|---|---|
20110224977 A1 | Sep 2011 | US |