Embodiments of the present disclosure relate to a technology for generating a speech video on the basis of machine learning.
Recently, various types of content have been generated through the use of artificial intelligence technology, in line with technological developments in the artificial intelligence field. As an example thereof, in the case that a spoken message is intended to be delivered, a speech video in which a famous person, such as a President, delivers the message as a speech may be generated from the spoken message in order to attract people's attention. The speech video of the famous person may be generated by changing the shape of the person's mouth to match the words of a specific message, as if the famous person were speaking.
In this regard, in the related art, a method of generating landmarks or key points related to a voice from an existing speech image, learning the landmarks or key points, and then synthesizing an image matching an input voice using a learned model has been used. However, in this related-art technology, for such learning, a process of extracting key points and transforming and inverse transforming the extracted key points to a standard space (i.e., a position facing the front from the center of the screen) is essentially required, and a step of synthesizing the key points and a step of synthesizing images are required. Accordingly, the process is complicated, which is problematic.
In addition, in the case that no key points are used, a method of extracting a face portion, arranging the size and position, and then synthesizing an image matching an input voice is used. Since a natural movement of a person is not reflected, a resultant image may be unnatural, which is problematic.
Embodiments of the present disclosure provide a method and device for generating a speech video on the basis of machine learning, wherein the method and device may reflect movements or gestures occurring in the case of a voice speech.
Embodiments of the present disclosure also provide a method and device for generating a speech video on the basis of machine learning, wherein the method and device may simplify a neural network structure.
According to an embodiment, a device for generating a speech video having one or more processors and a memory storing one or more programs executable by the one or more processors comprises: a first encoder configured to receive a person background image corresponding to a video part of a speech video of a person and extract an image feature vector from the person background image; a second encoder configured to receive a speech audio signal corresponding to an audio part of the speech video and extract a voice feature vector from the speech audio signal; a combiner configured to generate a combined vector by combining the image feature vector output from the first encoder and the voice feature vector output from the second encoder; and a decoder configured to reconstruct the speech video of the person using the combined vector as an input, wherein the person background image input to the first encoder comprises a face and an upper body of the person, with a portion related to speech of the person being covered with a mask.
The person background image input to the first encoder and the speech audio signal input to the second encoder may be time-synchronized.
The decoder may be a machine learning model trained to reconstruct the portion of the person background image covered with the mask based on the voice feature vector.
When the person background image is input to the first encoder, and a speech audio signal not related to the person background image is input to the second encoder, the combiner may be further configured to generate the combined vector by combining the image feature vector output from the first encoder and the voice feature vector output from the second encoder, and the decoder may be further configured to generate the speech video of the person by receiving the combined vector, and by reconstructing the portion related to the speech in the person background image based on the speech audio signal not related to the person background image.
The device may further include at least one residual block provided between the combiner and the decoder, wherein the at least one residual block may use the combined vector output from the combiner as an input value, and may be trained to minimize a difference between the input value and an output value output from the at least one residual block.
The device may further include: an attention unit configured to receive the speech video output from the decoder and generate an attention map by determining an attention weight for each pixel of the speech video; a speech-related portion extractor configured to receive the speech video output from the decoder and output a speech-related image by extracting a speech-related portion from the speech video; and a reconstruction outputter configured to receive the person background image input to the first encoder, the attention map, and the speech-related image and output a final speech video of the person.
The reconstruction outputter may be further configured to reconstruct a portion of the final speech video not related to the speech on basis of the person background image and a portion of the final speech video related to the speech on basis of the speech-related image.
The reconstruction outputter may be further configured to generate the final speech video by the following equation:
(equation)
P=A·I+(1−A)·C,
According to another embodiment, a device for generating a speech video having one or more processors and a memory storing one or more programs executable by the one or more processors comprises: a first encoder configured to receive person background images corresponding to video parts of speech videos of a plurality of persons and extract an image feature vector from each of the person background images; a second encoder configured to receive speech audio signals corresponding to audio parts of the speech videos of the plurality of persons and extract a voice feature vector from each of the speech audio signals; a person information embedder configured to receive person identification information for the plurality of persons and generate an embedding vector by embedding the person identification information; a combiner configured to generate a combined vector by combining the image feature vector output from the first encoder, the voice feature vector output from the second encoder, and the embedding vector output from the person information embedder; and a decoder configured to reconstruct the speech videos of the plurality of persons using the combined vector as an input, wherein each of the person background images input to the first encoder comprises a face and an upper body of a person, with a portion related to speech of the person being covered with a mask According to another embodiment, a method for generating a speech video executed by a computing device including one or more processors and a memory storing one or more programs executable by the one or more processors comprises: receiving a person background image corresponding to a video part of a speech video of the person; extracting an image feature vector from the person background image; receiving a speech audio signal corresponding to an audio part of the speech video; extracting a voice feature vector from the speech audio signal; generating a combined vector by combining the image feature vector output from a first encoder and the voice feature vector output from a second encoder; and reconstructing the speech video of the person using the combined vector as an input, wherein the person background image input to the first encoder comprises a face and an upper body of the person, with a portion of the person background image related to speech of the person being covered with a mask.
According to another embodiment, a method for generating a speech video executed by a computing device including one or more processors and a memory storing one or more programs executable by the one or more processors comprises: receiving person background images corresponding to video parts of speech videos of a plurality of persons; extracting an image feature vector from each of the person background images; receiving speech audio signals corresponding to audio parts of the speech videos of the plurality of persons; extracting a voice feature vector from each of the speech audio signals; receiving person identification information for the plurality of persons; generating an embedding vector by embedding the person identification information; generating a combined vector by combining the image feature vector output from the first encoder, the voice feature vector output from the second encoder, and the embedding vector; and reconstructing the speech videos of the plurality of persons using the combined vector as an input, wherein each of the person background images input to the first encoder comprises a face and an upper body of a person, with a portion related to speech of the person being covered with a mask.
According to embodiments of the present disclosure, learning is performed using the person background image including the face and the upper body in a situation in which the portions related to a speech are masked. Thus, it is possible to generate a speech video by reflecting gestures or characteristics unique to the person, such as movements of the face, neck, shoulders, and the like of the person, which occur when the person is speaking. Consequently, it is possible to generate a video containing a more natural speech. In addition, it is possible to generate the speech video using a single neural network model without a separate key point estimation process by inputting the video part of the speech video to the first encoder, inputting the audio part of the speech video to the second encoder, and reconstructing the masked portions related to the speech from the audio.
In addition, since the speech video including not only the face but also the upper body is generated, the videos may be naturally combined without an additional transformation or synthesizing process on the other portions (e.g., the trunk, arms, or legs) of the body of the corresponding person.
Hereinafter, specific embodiments of the present disclosure will be described with reference to the accompanying drawings. The following detailed description is provided to assist in gaining a comprehensive understanding of at least one of a method, a device, and a system to be described herein. However, the detailed description is merely exemplary, and the present disclosure is not limited thereto.
In the description of embodiments of the present disclosure, a detailed description of known technologies related to the present disclosure will be omitted in the case in which the subject matter of the present disclosure may be rendered unclear thereby. Terms to be used hereinafter will be defined in consideration of functions thereof in embodiments of the present disclosure, but may vary depending on the intentions of users or operators, as well as in practice. Therefore, the terms shall be defined on the basis of the descriptions throughout the specification. The terms used in the detailed description shall be interpreted as being illustrative, while not being limitative, of embodiments. Unless clearly used otherwise, a singular form includes a plural meaning. It shall be understood that expressions such as “comprise,” “include,” and “have,” as used herein, are for indicating certain features, numbers, steps, operations, elements, a portion or combinations thereof and are not to be interpreted as excluding the presence or possibility of one or more features, numbers, steps, operations, elements, a portion or combinations thereof other than the above.
In the following description, terms, such as “sending,” “communication,” “transmission,” and “reception” of a signal or information include not only direct transfer of a signal or information from a first element to a second element, but also the transfer of a signal or information from the first element to the second element through a third intervening element. In particular, the “transmission” or “sending” of a signal or information to the first element refers to a final designation of the signal or information but does not refer to a direct destination. This is the same regarding the “reception” of a signal or information. In addition, herein, a “relation” of two or more pieces of data or information indicates that acquisition of first data (or information) may acquire second data (or information) on the basis of the first data (or information).
In addition, terms, such as first and second, may be used in describing a variety of elements, but the elements are not limited by such terms. Such terms may be used to distinguish one element from other elements. For example, first element may be referred to as a second element and, in a similar manner, a second element may be referred to as first element without departing from the scope of the present disclosure.
The configuration of the device 100 for generating a speech video illustrated in
The first encoder 102 may be a machine learning model that is trained to extract an image feature vector using a person background image as an input. Hereinafter, the term “vector” may be used with a meaning encompassing a “tensor.”
Here, the person background image input to the first encoder 102 is an image in which a person utters (speaks). The person background image may be an image including a face and an upper body of a person. That is, the person background image may include not only the face but also the upper body of a person so that movements of the face, neck, shoulders, and the like occurring when the corresponding person is speaking may be seen.
In the person background image input to the first encoder 102, portions related to the speech may be masked. That is, in the person background image, the portions related to the speech (e.g., the mouth and portions around the mouth) may be covered with a mask M. In addition, during a masking process, the portions related to movements of the face, neck, shoulders, and the like caused by the speech of the person in the person background image may not be masked. Then, the first encoder 102 extracts an image feature vector from portions of the person background image, except for the portions related to the speech.
The first encoder 102 may include at least one convolutional layer and at least one pooling layer. The convolutional layer may extract feature values of pixels corresponding to a filter having a predetermined size (e.g., 3×3 pixel size) while moving the filter at predetermined intervals in the input person background image. The pooling layer may perform down-sampling by using an output of the convolutional layer as an input.
The second encoder 104 is a machine learning model that is trained to extract a voice feature vector using a speech audio signal as an input. Here, the speech audio signal corresponds to an audio part of the person background image (i.e., an image in which a person is speaking) input to the first encoder 102. In other words, in a video in which a person speaks (hereinafter, referred to as a “speech video”), a video part thereof may be input to the first encoder 102, and an audio part thereof may be input to the second encoder 104. The second encoder 104 may include at least one convolutional layer and at least one pooling layer, but the neural network structure of the second encoder 104 is not limited thereto.
The time of the person background image input to the first encoder 102 and the time of the speech audio signal input to the second encoder 104 may be synchronized. That is, in the speech video, in the same time section, the video part may be input to the first encoder 102, and the audio part may be input to the second encoder 104. Here, the person background image and the speech audio signal may be input to the first encoder 102 and the second encoder 104, respectively, at predetermined unit times (e.g., a single frame or a plurality of continuous frames).
The combiner 106 may generate a combined vector by combining an image feature vector output from the first encoder 102 and a voice feature vector output from the second encoder 104. In an example embodiment, the combiner 106 may generate a combined vector by concatenating the image feature vector and the voice feature vector, but is not limited thereto.
The decoder 108 may reconstruct the speech video of a person using the combined vector output from the combiner 106 as an input. Specifically, the decoder 108 may be a machine learning model that is trained to reconstruct a portion (i.e., a portion related to a speech) covered with the mask M, of the image feature vector output from the first encoder 102 (i.e., the feature of a video part of the speech video, in which a portion related to the speech is covered with the mask), on the basis of the voice feature vector output from the second encoder 104 (i.e., the feature of the audio part of the speech video). That is, the decoder 108 may be a model that is trained to reconstruct a masked portion in the person background image using the audio signal when a portion related to the speech in the person background image is masked.
In an example embodiment, the decoder 108 may generate the speech video by performing deconvolution on the combined vector in which the image feature vector output from the first encoder 102 and the voice feature vector output from the second encoder 104 are combined, followed by up-sampling. The decoder 108 may compare the generated speech video with the original speech video (i.e., an answer value) and thus adjust learning parameters (e.g., the loss function or the Softmax function) so that the generated speech video (i.e., a video in which the portion related to the speech are reconstructed through the audio part) is similar to the original speech video.
The second encoder 104 receives a speech audio signal as an input. Here, the speech audio signal may not be related to the person background image input to the first encoder 102. For example, the speech audio signal may be a speech audio signal of another person different from the person in the person background image. However, the speech audio signal is not limited thereto, and may be a speech audio signal generated from a speech made by the person in the person background image. Here, the speech of the corresponding person may be generated in a background or a situation not related to the person background image. The second encoder 104 may generate the voice feature vector from the speech audio signal.
The combiner 106 may generate a combined vector by combining the image feature vector output from the first encoder 102 and the voice feature vector output from the second encoder 104.
The decoder 108 may reconstruct and output the speech video using the combined vector as an input. That is, the decoder 108 may generate the speech video by reconstructing a portion of the person background image related to the speech on the basis of the voice feature vector output from the second encoder 104. In this case, although the speech audio signal input to the second encoder 104 is a speech not related to the person background image (e.g., a speech not made by the person in the person background image), the speech video is generated as if the person in the person background image is speaking.
According to embodiments of the present disclosure, the learning is performed using the person background image including the face and the upper body as an input in a situation in which the portions related to the speech are masked. Thus, it is possible to generate the speech video by reflecting gestures or characteristics unique to the person, such as movements of the face, neck, shoulders, and the like of the person, which occur when the person is speaking. Consequently, it is possible to generate a more natural speech video.
In addition, it is possible to generate the speech video using a single neural network model without a separate key point estimation process by inputting the video part of the speech video to the first encoder 102, inputting the audio part of the speech video to the second encoder 104, and reconstructing the masked portions related to the speech from the audio.
In addition, since the speech video including not only the face but also the upper body of the corresponding person is generated, it can be naturally pasted without additional transformation or synthesis of other body parts of the person (e.g., the trunk, arms, or legs).
Referring to
The residual blocks 110 may include one or more convolutional layers. The residual blocks 110 may have a structure performing convolution to an input value (i.e., a combined vector output from the combiner 106) and adding the input value to a result value obtained by performing the convolution. The residual blocks 110 may be trained to minimize a difference between the input value and the output value of the residual blocks 110. In this manner, the image feature vector and the voice feature vector extracted from the video and the audio of the speech video, respectively, may be systematically combined to be used as an input to the decoder 108.
Referring to
Here, the attention unit 112 and the speech-related portion extractor 114 may be connected to output of the decoder 108, respectively. That is, each of the attention unit 112 and the speech-related portion extractor 114 may receive the speech video (hereinafter, also referred to as a first-reconstructed speech video) output from the decoder 108 as an input.
The attention unit 112 may output an attention map by determining pixel-specific attention weights of the first-reconstructed speech video. Each of the attention weights may be a value in the range of 0 to 1.
Specifically, in second reconstruction of the speech video according to the pixels of the first-reconstructed speech video by the reconstruction outputter 116, the attention unit 112 may set the attention weights for determining whether to use a person background image (i.e., an image in which speech-related portions are covered with a mask) used as an input to the first encoder 102 or a speech-related image output from the speech-related portion extractor 114.
The speech-related portion extractor 114 may output the speech-related image by extracting the portions related to the speech (i.e., the speech-related portions) from the first-reconstructed speech video. In an example embodiment, the speech-related portion extractor 114 may generate a speech-related image by extracting pixel values of the speech-related portions of the first-reconstructed speech video and filling the remaining portions with random values (e.g., unused values).
The reconstruction outputter 116 may output a final speech video by combining the person background image used as an input to the first encoder 102, the attention map output from the attention unit 112, and the speech-related image output from the speech-related portion extractor 114.
The reconstruction outputter 116 may reconstruct the final speech video using the person background image for the portions not related to the speech and reconstruct the final speech video using the speech-related image for the speech-related portions, on the basis of the attention map (including pixel-specific attention weight values).
In an example embodiment, the reconstruction outputter 116 may reconstruct the final speech video P by the following Equation 1.
P=A·I+(1−A)·C (1)
According to Equation 1, as A is closer to 0, the final speech video is more influenced by the speech-related image. On the other hand, as A is closer to 1, the final speech video is more influenced by the person background image. Thus, the attention unit 112 may determine the pixel-specific attention weights so that each of the attention weights of the portions not related to the speech is close to 1 and each of the attention weights of the speech-related portions is close to 0.
In addition, in the embodiment of the present disclosure, as illustrated in
In addition, a person information embedder 118 may receive person identification information regarding the plurality of persons. The person information embedder 118 may generate an embedding vector by embedding the person identification information regarding each of the persons.
The combiner 106 may generate a combined vector by combining the embedding vector, the image feature vector, and voice feature vector regarding each of the persons. The decoder 108 may reconstruct the speech video regarding each of the persons on the basis of the combined vector regarding each of the persons.
Since the speech videos of the plurality of persons are learned using a single neural network model as described above, common portions of images and voices of the plurality of persons can be learned. Accordingly, the learning can be performed more rapidly and efficiently.
The illustrated computing environment 10 includes a computing device 12. According to an embodiment, the computing device 12 may be the device 100 for generating a speech video.
The computing device 12 includes at least one processor 14, a computer readable storage medium 16, and a communication bus 18. The processor 14 may allow the computing device 12 to operate according to the example embodiments described above. For example, the processor 14 may execute one or more programs stored in the computer readable storage medium 16. The one or more programs may include one or more computer executable instructions. The computer executable instructions may be configured to allow the computing device 12 to perform the operations according to the example embodiments when executed by the processor 14.
The computer readable storage medium 16 may be configured to store computer executable instructions, program codes, program data, and/or other suitable forms of information. A program 20 stored in the computer readable storage medium 16 may include a set of instructions executable by the processor 14. According to an embodiment, the computer readable storage medium 16 may be a memory (e.g., a volatile memory such as a random access memory (RAM), a non-volatile memory, or a combination thereof), one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, other types of storage media which can be accessed by the computing device 12 and store intended information, or combinations thereof.
The communication bus 18 may include the processor 14 and the computer readable storage medium 16, and interconnect various components of the computing device 12 to each other.
The computing device 12 may include one or more input/output (I/O) interfaces 22 providing an interface for one or more I/O devices 24 and one or more network communication interfaces 26. The I/O interface 22 and the network communication interfaces 26 may be connected to the communication bus 18. The I/O devices 24 may include input devices, such as a pointing device (e.g., a mouse and a track pad), a keyboard, a touch input device (e.g., a touch pad and a touch screen), a voice or sound input device, various types of sensors, and/or a capturing device, and/or output devices, such as a display device, a printer, a speaker, and/or a network card. Each of the I/O devices 24 may be one component constituting the computing device 12, may be included in the computing device 12, or may be connected to the computing device 12 as a device separate from the computing device 12.
Although the exemplary embodiments of the present disclosure have been described in detail hereinabove, a person having ordinary knowledge in the technical field to which the present disclosure pertains will appreciate that various modifications are possible to the foregoing embodiments without departing from the scope of the present disclosure.
Therefore, the scope of protection of the present disclosure shall not be limited to the foregoing embodiments but shall be defined by the appended Claims and equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
10-2019-0074139 | Jun 2019 | KR | national |
10-2020-0070743 | Jun 2020 | KR | national |
This application claims benefit under 35 U.S.C. 119, 120, 121, or 365(c), and is a National Stage entry from International Application No. PCT/KR2020/007974, filed Jun. 19, 2020, which claims priority to the benefit of Korean Patent Application Nos. 10-2019-0074139 filed on Jun. 21, 2019 and 10-2020-0070743 filed on Jun. 11, 2020 in the Korean Intellectual Property Office, the entire contents of which are incorporated herein by reference.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/KR2020/007974 | 6/19/2020 | WO |