KR102558530B1 - 립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 - Google Patents
립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 Download PDFInfo
- Publication number
- KR102558530B1 KR102558530B1 KR1020210164873A KR20210164873A KR102558530B1 KR 102558530 B1 KR102558530 B1 KR 102558530B1 KR 1020210164873 A KR1020210164873 A KR 1020210164873A KR 20210164873 A KR20210164873 A KR 20210164873A KR 102558530 B1 KR102558530 B1 KR 102558530B1
- Authority
- KR
- South Korea
- Prior art keywords
- image
- data
- voice
- neural network
- learning
- Prior art date
Links
- 238000013528 artificial neural network Methods 0.000 title claims abstract description 133
- 238000000034 method Methods 0.000 title claims abstract description 60
- 238000012549 training Methods 0.000 title claims description 16
- 238000004590 computer program Methods 0.000 title claims description 6
- 230000001360 synchronised effect Effects 0.000 claims abstract description 9
- 230000037303 wrinkles Effects 0.000 claims description 4
- 238000010586 diagram Methods 0.000 description 27
- 230000006870 function Effects 0.000 description 23
- 238000004891 communication Methods 0.000 description 12
- 238000012545 processing Methods 0.000 description 11
- 238000005516 engineering process Methods 0.000 description 4
- 238000013527 convolutional neural network Methods 0.000 description 3
- 230000014509 gene expression Effects 0.000 description 3
- 238000011176 pooling Methods 0.000 description 3
- 230000000306 recurrent effect Effects 0.000 description 3
- 230000004044 response Effects 0.000 description 3
- 238000013459 approach Methods 0.000 description 2
- 238000004422 calculation algorithm Methods 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000013473 artificial intelligence Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 238000013135 deep learning Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 238000003062 neural network model Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000005236 sound signal Effects 0.000 description 1
- 238000003786 synthesis reaction Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
- 238000000844 transformation Methods 0.000 description 1
Images
Classifications
-
- 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
- G10L21/00—Speech or voice signal processing techniques to produce another audible or non-audible signal, e.g. visual or tactile, in order to modify its quality or its intelligibility
- G10L21/06—Transformation of speech into a non-audible representation, e.g. speech visualisation or speech processing for tactile aids
- G10L21/10—Transforming into visible information
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/04—Architecture, e.g. interconnection topology
- G06N3/045—Combinations of networks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/04—Architecture, e.g. interconnection topology
- G06N3/045—Combinations of networks
- G06N3/0455—Auto-encoder networks; Encoder-decoder networks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/08—Learning methods
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/08—Learning methods
- G06N3/09—Supervised learning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T13/00—Animation
- G06T13/20—3D [Three Dimensional] animation
- G06T13/40—3D [Three Dimensional] animation of characters, e.g. humans, animals or virtual beings
-
- 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/04—Segmentation; Word boundary detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/4302—Content synchronisation processes, e.g. decoder synchronisation
- H04N21/4307—Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen
-
- 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
- G10L21/00—Speech or voice signal processing techniques to produce another audible or non-audible signal, e.g. visual or tactile, in order to modify its quality or its intelligibility
- G10L21/06—Transformation of speech into a non-audible representation, e.g. speech visualisation or speech processing for tactile aids
- G10L21/10—Transforming into visible information
- G10L2021/105—Synthesis of the lips movements from speech, e.g. for talking heads
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Health & Medical Sciences (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Multimedia (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Artificial Intelligence (AREA)
- General Health & Medical Sciences (AREA)
- Molecular Biology (AREA)
- Biophysics (AREA)
- General Engineering & Computer Science (AREA)
- Biomedical Technology (AREA)
- Mathematical Physics (AREA)
- Software Systems (AREA)
- Evolutionary Computation (AREA)
- Life Sciences & Earth Sciences (AREA)
- Signal Processing (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Human Computer Interaction (AREA)
- Acoustics & Sound (AREA)
- Quality & Reliability (AREA)
- Image Analysis (AREA)
Abstract
본 발명의 일 실시예에 따른 컴퓨팅 장치가 입력된 음성과 동기화된 입술 모양을 생성하는 인공 신경망을 학습하는 방법은, 학습 객체의 발화 구간을 포함하는 제1 영상으로부터 학습 데이터를 생성하는 단계로써, 상기 발화 구간에서의 발화 음성, 상기 발화 구간을 구성하는 적어도 하나의 음성 관련 이미지 및 상기 발화 구간과 상이한 구간을 구성하는 적어도 하나의 음성 무관 이미지를 포함하고; 및 상기 학습 데이터에 기초하여, 음성 및 입술의 형상을 포함하는 적어도 하나의 제1 이미지의 입력에 따라 상기 제1 이미지에 포함된 입술의 형상이 상기 음성에 따라 변형된 이미지인 제2 이미지를 출력하는 제1 인공 신경망을 학습하는 단계;를 포함할 수 있다.
Description
본 발명은 음성과 입술 모양이 동기화된 영상을 제공하는 인공 신경망의 학습 방법에 관한 것이다.
정보통신 기술의 발달로 많은 애플리케이션에 인공 지능 기술의 도입이 이루어지고 있다. 종래에는 특정 인물이 특정 주제에 대해 이야기하는 영상을 생성하기 위해서는 해당 인물이 실제로 해당 주제의 이야기를 하는 영상을 카메라 등으로 획득하는 방법만이 유일하였다.
또한 일부 종래기술에 있어서 영상 합성 기술 등을 이용하여 특정 인물의 이미지나 영상에 기반하여 합성된 영상을 생성하기도 하였으나, 이와 같은 영상은 여전히 인물의 입모양 등이 부자연스러운 문제점이 있었다.
본 발명은 상술한 문제점을 해결하기 위한 것으로, 보다 자연스러운 영상을 생성하고자 한다.
특히 본 발명은 실제 인물에 의한 촬영 없이도, 입모양이 자연스러운 영상을 생성하고자 한다.
또한 본 발명은 인공 신경망의 사용에도 불구하고 영상의 생성에 있어서 사용되는 서버의 리소스와 네트워크 리소스의 사용을 최소화하고자 한다.
본 발명의 일 실시예에 따른 컴퓨팅 장치가 입력된 음성과 동기화된 입술 모양을 생성하는 인공 신경망을 학습하는 방법은, 학습 객체의 발화 구간을 포함하는 제1 영상으로부터 학습 데이터를 생성하는 단계로써, 상기 발화 구간에서의 발화 음성, 상기 발화 구간을 구성하는 적어도 하나의 음성 관련 이미지 및 상기 발화 구간과 상이한 구간을 구성하는 적어도 하나의 음성 무관 이미지를 포함하고; 및 상기 학습 데이터에 기초하여, 음성 및 입술의 형상을 포함하는 적어도 하나의 제1 이미지의 입력에 따라 상기 제1 이미지에 포함된 입술의 형상이 상기 음성에 따라 변형된 이미지인 제2 이미지를 출력하는 제1 인공 신경망을 학습하는 단계;를 포함할 수 있다.
상기 학습 데이터를 생성하는 단계는 상기 제1 영상으로부터 상기 학습 객체의 입술의 형상을 포함하는 제1 데이터를 생성하는 단계; 상기 발화 음성을 포함하는 제2 데이터를 생성하는 단계; 및 상기 적어도 하나의 음성 관련 이미지 및 상기 적어도 하나의 음성 무관 이미지를 병합한 제3 데이터를 생성하는 단계;를 포함할 수 있다. 이때 상기 제1 데이터, 상기 제2 데이터 및 상기 제3 데이터는 상기 학습 데이터를 구성하는 데이터일 수 있다.
상기 제1 인공 신경망은 상기 제1 데이터, 상기 제2 데이터 및 상기 제3 데이터 간의 상관관계를 학습한 신경망일 수 있다.
상기 제1 인공 신경망을 학습하는 단계는 상기 제1 인공 신경망에 상기 제1 데이터 및 상기 제2 데이터의 입력에 따라 상기 제3 데이터가 출력되도록 상기 제1 인공 신경망을 학습시키는 단계;를 포함할 수 있다.
상기 제3 데이터의 상기 음성 무관 이미지에 해당하는 데이터는 상기 학습 객체의 발화에 따른 입모양을 제외한 나머지 형상을 제공하는 데이터일 수 있다.
상기 나머지 형상은 상기 학습 객체의 입 주변부 형상, 상기 학습 객체의 치아의 형상, 상기 학습 객체의 얼굴의 주름 패턴, 상기 학습 객체의 피부 색상, 상기 학습 객체의 턱 모양, 상기 학습 객체의 목 모양 및 상기 학습 객체의 의상 색상 중 적어도 어느 하나를 포함할 수 있다.
본 발명의 일 실시예에 따른 컴퓨팅 장치가 음성과 입술 모양이 동기화된 영상을 제공하는 립싱크 영상을 제공하는 방법은, 적어도 하나의 프레임으로 구성되며 대상 객체를 묘사하는 탬플릿 영상을 획득하는 단계; 상기 대상 객체의 목소리로 사용 할 대상 음성을 획득하는 단계; 및 학습 된 제1 인공 신경망을 이용하여, 상기 탬플릿 영상의 프레임 별로 상기 음성에 대응되는 이미지를 생성하는 단계;를 포함할 수 있다. 이때 상기 제1 인공 신경망은 상기 대상 객체의 입술의 형상을 포함하는 제1 데이터, 상기 대상 음성을 포함하는 제2 데이터의 입력에 따라 상기 대상 객체의 발화에 따른 입모양과 상기 대상 객체의 입모양을 제외한 나머지 형상을 포함하는 제3 데이터를 출력하는 신경망일 수 있다.
상기 제3 데이터는 상기 대상 음성과 관련된 이미지 및 상기 대상 음성과 무관한 이미지를 병합한 데이터일 수 있다.
본 발명의 일 실시예에 따른 음성과 입술 모양이 동기화된 영상을 제공하는 립싱크 영상 제공 장치는 적어도 하나의 프레임으로 구성되며 대상 객체를 묘사하는 탬플릿 영상을 획득하고, 상기 대상 객체의 목소리로 사용 할 대상 음성을 획득하고, 학습 된 제1 인공 신경망을 이용하여, 상기 탬플릿 영상의 프레임 별로 상기 음성에 대응되는 입술 이미지를 생성하고, 상기 탬플릿 영상 내 프레임 식별 정보, 상기 입술 이미지, 상기 탬플릿 영상 내 프레임에서 상기 입술 이미지의 위치정보를 포함하는 립싱크 데이터를 생성할 수 있다.
상기 장치는 상기 립싱크 데이터를 사용자 단말에 전송할 수 있다.
상기 사용자 단말은 상기 프레임 식별 정보를 참조하여, 메모리로부터 상기 프레임 식별 정보에 상응하는 프레임을 리드(Read)하고, 상기 입술 이미지의 위치정보에 기반하여, 상기 리드 된 프레임 상에 상기 입술 이미지를 오버랩 시켜 출력 프레임을 생성할 수 있다.
상기 장치는 상기 탬플릿 영상의 프레임 단위로 상기 립싱크 데이터를 생성하고, 상기 사용자 단말은 상기 프레임 단위로 생성된 립싱크 데이터를 수신하고, 상기 립싱크 데이터 별로 상기 출력 프레임을 생성할 수 있다.
상기 장치는 상기 립싱크 데이터를 상기 사용자 단말에 전송하기 이전에, 상기 탬플릿 영상의 식별 정보, 상기 탬플릿 영상 및 상기 음성 중 적어도 하나를 상기 사용자 단말에 전송할 수 있다.
상기 제1 인공 신경망은 음성 및 제1 입술 이미지의 입력에 따라 상기 제1 입술 이미지가 상기 음성에 따라 변형된 이미지인 제2 입술 이미지를 출력하도록 학습 된 신경망일 수 있다.
상기 장치는 학습 된 제2 인공 신경망을 이용하여, 텍스트로부터 상기 대상 음성을 생성하고, 상기 제2 인공 신경망은 텍스트의 입력에 따라 입력된 텍스트와 대응되는 음성을 출력하도록 학습 된 신경망일 수 있다.
본 발명의 일 실시예에 따른 음성과 입술 모양이 동기회된 영상을 표시하는 립싱크 영상 표시 장치는, 서버로부터 탬플릿 영상 및 대상 객체의 목소리로 사용 할 대상 음성을 수신하고, 프레임 별로 생성된 립싱크 데이터를 수신하고, 상기 립싱크 데이터는 탬플릿 영상 내 프레임 식별 정보, 입술 이미지, 상기 탬플릿 영상 내 프레임에서 상기 입술 이미지의 위치정보를 포함하고, 상기 탬플릿 영상, 상기 대상 음성 및 상기 립싱크 데이터를 이용하여 립싱크 영상을 표시할 수 있다.
상기 장치는 상기 립싱크 데이터에 포함된 프레임 식별 정보를 참조하여, 메모리로부터 상기 프레임 식별 정보에 상응하는 프레임을 리드(Read)하고, 상기 립싱크 데이터에 포함된 상기 입술 이미지의 위치정보에 기반하여, 상기 리드 된 프레임 상에 상기 립싱크 데이터에 포함된 입술 이미지를 오버랩 시켜 출력 프레임을 생성하고, 생성된 출력 프레임을 표시할 수 있다.
상기 장치는 상기 대상 음성의 흐름에 따른 복수의 립싱크 데이터를 수신하고, 상기 복수의 립싱크 데이터 각각으로부터 생성된 출력 프레임을 시간의 흐름에 따라 순차적으로 표시할 수 있다.
본 발명의 일 실시예에 따른 음성과 입술 모양이 동기화된 영상을 제공하는 립싱크 영상 제공 방법은, 적어도 하나의 프레임으로 구성되며 대상 객체를 묘사하는 탬플릿 영상을 획득하는 단계; 상기 대상 객체의 목소리로 사용 할 대상 음성을 획득하는 단계; 학습 된 제1 인공 신경망을 이용하여, 상기 탬플릿 영상의 프레임 별로 상기 음성에 대응되는 입술 이미지를 생성하는 단계; 및 상기 탬플릿 영상 내 프레임 식별 정보, 상기 입술 이미지, 상기 탬플릿 영상 내 프레임에서 상기 입술 이미지의 위치정보를 포함하는 립싱크 데이터를 생성하는 단계;를 포함할 수 있다.
본 발명에 따르면 보다 자연스러운 인물 영상을 생성할 수 있다.
특히 본 발명에 따르면 인물에 의한 실제 촬영 없이도, 입모양이 자연스러운 영상을 생성할 수 있다.
아울러 본 발명에 따르면 인공 신경망의 사용에도 불구하고 영상의 생성에 있어서 사용되는 서버의 리소스와 네트워크 리소스의 사용을 최소화 할 수 있다.
도 1은 본 발명의 일 실시예에 따른 립싱크 영상 생성 시스템의 구성을 개략적으로 도시한 도면이다.
도 2는 본 발명의 일 실시예에 따른 서버(100)의 구성을 개략적으로 도시한 도면이다.
도 3은 본 발명의 일 실시예에 따른 서비스 서버(300)의 구성을 개략적으로 도시한 도면이다.
도 4 및 도 5는 본 발명의 일 실시예에 따른 서버(100)에 의해 학습된 인공 신경망의 예시적인 구조를 설명하기 위한 도면이다.
도 6은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(510)를 이용하여 제1 인공 신경망(520)을 학습하는 방법을 설명하기 위한 도면이다.
도 7은 본 발명의 일 실시예에 따른 서버(100)가 학습된 제1 인공 신경망(520)을 이용하여 입술 이미지(543)를 출력하는 과정을 설명하기 위한 도면이다.
도 8은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(550)를 이용하여 제2 인공 신경망(560)을 학습하는 방법을 설명하기 위한 도면이다.
도 9는 본 발명의 일 실시예에 따른 서버(100)가 제2 인공 신경망(560)을 이용하여 대상 음성(580)을 출력하는 과정을 설명하기 위한 도면이다.
도 10 및 도 11은 본 발명의 일 실시예에 따른 서버(100)에 의해 수행되는 립싱크 영상 제공 방법과 사용자 단말(200)에 의해 제공되는 립싱크 영상 표시 방법을 설명하기 위한 흐름도이다.
도 12는 본 발명의 일 실시예에 따른 사용자 단말(200)이 출력 프레임을 생성하는 방법을 설명하기 위한 도면이다.
도 13은 본 발명의 다른 실시예에 따른 서버(100)가 제1 인공 신경망의 학습을 위한 학습 데이터를 생성하는 과정을 설명하기 위한 도면이다.
도 14는 본 발명의 다른 실시예에 따른 서버(100)가 생성한 학습 데이터(850)의 예시이다.
도 15는 제1 인공 신경망(520)을 설명하기 위한 도면이다.
도 16은 본 발명의 일 실시예에 따른 제3 데이터(833)의 음성 무관 이미지(835)를 설명하기 위한 도면이다.
도 17은 본 발명의 다른 실시예에 따른 서버(100)에 의해 제1 인공 신경망이 학습되는 과정을 설명하기 위한 흐름도이다.
도 2는 본 발명의 일 실시예에 따른 서버(100)의 구성을 개략적으로 도시한 도면이다.
도 3은 본 발명의 일 실시예에 따른 서비스 서버(300)의 구성을 개략적으로 도시한 도면이다.
도 4 및 도 5는 본 발명의 일 실시예에 따른 서버(100)에 의해 학습된 인공 신경망의 예시적인 구조를 설명하기 위한 도면이다.
도 6은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(510)를 이용하여 제1 인공 신경망(520)을 학습하는 방법을 설명하기 위한 도면이다.
도 7은 본 발명의 일 실시예에 따른 서버(100)가 학습된 제1 인공 신경망(520)을 이용하여 입술 이미지(543)를 출력하는 과정을 설명하기 위한 도면이다.
도 8은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(550)를 이용하여 제2 인공 신경망(560)을 학습하는 방법을 설명하기 위한 도면이다.
도 9는 본 발명의 일 실시예에 따른 서버(100)가 제2 인공 신경망(560)을 이용하여 대상 음성(580)을 출력하는 과정을 설명하기 위한 도면이다.
도 10 및 도 11은 본 발명의 일 실시예에 따른 서버(100)에 의해 수행되는 립싱크 영상 제공 방법과 사용자 단말(200)에 의해 제공되는 립싱크 영상 표시 방법을 설명하기 위한 흐름도이다.
도 12는 본 발명의 일 실시예에 따른 사용자 단말(200)이 출력 프레임을 생성하는 방법을 설명하기 위한 도면이다.
도 13은 본 발명의 다른 실시예에 따른 서버(100)가 제1 인공 신경망의 학습을 위한 학습 데이터를 생성하는 과정을 설명하기 위한 도면이다.
도 14는 본 발명의 다른 실시예에 따른 서버(100)가 생성한 학습 데이터(850)의 예시이다.
도 15는 제1 인공 신경망(520)을 설명하기 위한 도면이다.
도 16은 본 발명의 일 실시예에 따른 제3 데이터(833)의 음성 무관 이미지(835)를 설명하기 위한 도면이다.
도 17은 본 발명의 다른 실시예에 따른 서버(100)에 의해 제1 인공 신경망이 학습되는 과정을 설명하기 위한 흐름도이다.
본 발명은 다양한 변환을 가할 수 있고 여러 가지 실시예를 가질 수 있는 바, 특정 실시예들을 도면에 예시하고 상세한 설명에 상세하게 설명하고자 한다. 본 발명의 효과 및 특징, 그리고 그것들을 달성하는 방법은 도면과 함께 상세하게 후술되어 있는 실시예들을 참조하면 명확해질 것이다. 그러나 본 발명은 이하에서 개시되는 실시예들에 한정되는 것이 아니라 다양한 형태로 구현될 수 있다.
이하, 첨부된 도면을 참조하여 본 발명의 실시예들을 상세히 설명하기로 하며, 도면을 참조하여 설명할 때 동일하거나 대응하는 구성 요소는 동일한 도면부호를 부여하고 이에 대한 중복되는 설명은 생략하기로 한다.
이하의 실시예에서, 제1, 제2 등의 용어는 한정적인 의미가 아니라 하나의 구성 요소를 다른 구성 요소와 구별하는 목적으로 사용되었다. 이하의 실시예에서, 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 이하의 실시예에서, 포함하다 또는 가지다 등의 용어는 명세서상에 기재된 특징, 또는 구성요소가 존재함을 의미하는 것이고, 하나 이상의 다른 특징들 또는 구성요소가 부가될 가능성을 미리 배제하는 것은 아니다. 도면에서는 설명의 편의를 위하여 구성 요소들이 그 크기가 과장 또는 축소될 수 있다. 예컨대, 도면에서 나타난 각 구성의 크기 및 형태는 설명의 편의를 위해 임의로 나타내었으므로, 본 발명이 반드시 도시된 바에 한정되지 않는다.
도 1은 본 발명의 일 실시예에 따른 립싱크 영상 생성 시스템의 구성을 개략적으로 도시한 도면이다.
본 발명의 일 실시예에 따른 립싱크 영상 생성 시스템은 입술 이미지(서버에 의해 생성된)와 얼굴을 포함하는 탬플릿 프레임(영상 수신 장치의 메모리에 저장된)이 영상 수신 장치(예를 들어 사용자 단말)에서 오버랩 되어 표시되도록 할 수 있다.
이때 립싱크 영상 생성 시스템의 서버는 대상 객체의 목소리로 사용 할 음성으로부터 순차적인 입술 이미지를 생성할 수 있고, 영상 수신 장치는 순차적인 입술 이미지와 탬플릿 이미지를 오버랩 하여 표시함으로써 입모양과 음성이 일치되는 영상을 표시할 수 있다.
이와 같이 본 발명은 립싱크 영상을 생성함에 있어서, 일부 작업이 영상 수신 장치에서 수행되도록 하여, 서버의 리소스를 보다 효율적으로 사용할 수 있도록 하며 관련된 리소스 또한 보다 효율적으로 사용할 수 있도록 한다.
본 발명에서 제1 인공 신경망 및 제2 인공 신경망과 같은 '인공 신경망'은 용도에 따른 학습 데이터로 학습된 신경망으로, 머신 러닝(Machine Learning) 또는 딥러닝(Deep Learning) 기법에 의해 학습된 인공 신경망을 의미할 수 있다. 이와 같은 신경망의 구조에 대해서는 도 4 내지 도 5를 참조하여 후술한다.
본 발명의 일 실시예에 따른 립싱크 영상 생성 시스템은 도 1에 도시된 바와 같이 서버(100), 사용자 단말(200), 서비스 서버(300) 및 통신망(400)을 포함할 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 학습된 제1 인공 신경망을 이용하여 음성으로부터 입술 이미지를 생성하고, 생성된 입술 이미지를 사용자 단말(200) 및/또는 서비스 서버(300)에 제공할 수 있다.
이때 서버(100)는 탬플릿 영상의 프레임 별로 음성에 대응되는 입술 이미지를 생성하고, 탬플릿 영상 내 프레임 식별 정보, 생성된 입술 이미지, 입술 이미지의 탬플릿 프레임 내에서의 위치 정보를 포함하는 립싱크 데이터를 생성할 수 있다. 또한 서버(100)는 생성된 립싱크 데이터를 사용자 단말(200) 및/또는 서비스 서버(300)에 제공할 수 있다. 본 발명에서 이와 같은 서버(100)는 때때로 '립싱크 영상 제공 장치'로 명명되어 설명될 수 있다.
도 2는 본 발명의 일 실시예에 따른 서버(100)의 구성을 개략적으로 도시한 도면이다. 도 2를 참조하면, 본 발명의 일 실시예에 따른 서버(100)는 통신부(110), 제1 프로세서(120), 메모리(130) 및 제2 프로세서(140)를 포함할 수 있다. 또한 도면에는 도시되지 않았으나, 본 발명의 일 실시예에 따른 서버(100)는 입/출력부, 프로그램 저장부 등을 더 포함할 수 있다.
통신부(110)는 서버(100)가 사용자 단말(200) 및/또는 서비스 서버(300)와 같은 다른 네트워크 장치와 유무선 연결을 통해 제어 신호 또는 데이터 신호와 같은 신호를 송수신하기 위해 필요한 하드웨어 및 소프트웨어를 포함하는 장치일 수 있다.
제1 프로세서(120)는 학습된 인공 신경망들을 이용하여 입력 데이터로부터 출력 데이터를 생성하는 일련의 과정을 제어하는 장치일 수 있다. 가령 제1 프로세서(120)는 학습된 제1 인공 신경망을 이용하여 획득된 음성에 대응되는 입술 이미지를 생성하는 과정을 제어하는 장치일 수 있다.
이때 프로세서(Processor)는, 예를 들어 프로그램 내에 포함된 코드 또는 명령으로 표현된 기능을 수행하기 위해 물리적으로 구조화된 회로를 갖는, 하드웨어에 내장된 데이터 처리 장치를 의미할 수 있다. 이와 같이 하드웨어에 내장된 데이터 처리 장치의 일 예로써, 마이크로프로세서(Microprocessor), 중앙처리장치(Central Processing Unit: CPU), 프로세서 코어(Processor Core), 멀티프로세서(Multiprocessor), ASIC(Application-Specific Integrated Circuit), FPGA(Field Programmable Gate Array) 등의 처리 장치를 망라할 수 있으나, 본 발명의 범위가 이에 한정되는 것은 아니다.
메모리(130)는 서버(100)가 처리하는 데이터를 일시적 또는 영구적으로 저장하는 기능을 수행한다. 메모리는 자기 저장 매체(Magnetic Storage Media) 또는 플래시 저장 매체(Flash Storage Media)를 포함할 수 있으나, 본 발명의 범위가 이에 한정되는 것은 아니다. 가령 메모리(130)는 학습된 인공 신경망을 구성하는 데이터들(가령 계수들)을 일시적 및/또는 영구적으로 저장할 수 있다. 물론 메모리(130)는 인공 신경망을 학습하기 위한 학습 데이터 또는 서비스 서버(300)로부터 수신된 데이터를 저장할 수도 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
제2 프로세서(140)는 전술한 제1 프로세서(120)의 제어에 따라 연산을 수행하는 장치를 의미할 수 있다. 이때 제2 프로세서(140)는 전술한 제1 프로세서(120)보다 높은 연산 능력을 갖는 장치일 수 있다. 가령 제2 프로세서(140)는 GPU(Graphics Processing Unit)로 구성될 수 있다. 다만 이는 예시적인 것으로 본 발명의 사상이 이에 한정되는 것은 아니다. 본 발명의 일 실시예에서, 제2 프로세서(140)는 복수일 수도 있고, 단수일 수도 있다.
본 발명의 일 실시예에서 서비스 서버(300)는 서버(100)로부터 생성된 입술 이미지를 포함하는 립싱크 데이터를 수신하고, 이를 이용하여 출력 프레임을 생성한 뒤 다른 장치(예를 들어 사용자 단말(200))에 제공하는 장치일 수 있다.
본 발명의 다른 실시예에서, 서비스 서버(300)는 서버(100)에 의해 학습된 인공 신경망을 수신하여, 다른 장치(예를 들어 사용자 단말(200))의 요청에 따라 립싱크 데이터를 제공하는 장치일 수도 있다.
도 3은 본 발명의 일 실시예에 따른 서비스 서버(300)의 구성을 개략적으로 도시한 도면이다. 도 3을 참조하면, 본 발명의 일 실시예에 따른 서비스 서버(300)는 통신부(310), 제3 프로세서(320), 메모리(330) 및 제4 프로세서(340)를 포함할 수 있다. 또한 도면에는 도시되지 않았으나, 본 발명의 일 실시예에 따른 서비스 서버(300)는 입/출력부, 프로그램 저장부 등을 더 포함할 수 있다.
본 발명의 일 실시예에서 제3 프로세서(320)는 서버(100)로부터 생성된 입술 이미지를 포함하는 립싱크 데이터를 수신하고, 이를 이용하여 출력 프레임을 생성한 뒤 다른 장치(예를 들어 사용자 단말(200))에 제공하는 과정을 제어하는 장치일 수 있다.
한편 본 발명의 다른 실시예에서 제3 프로세서(320)는 학습된 인공 신경망(서버(100)로부터 수신된)을 이용하여 다른 장치(예를 들어 사용자 단말(200))의 요청에 따라 립싱크 데이터를 제공하는 장치일 수도 있다.
이때 프로세서(Processor)는, 예를 들어 프로그램 내에 포함된 코드 또는 명령으로 표현된 기능을 수행하기 위해 물리적으로 구조화된 회로를 갖는, 하드웨어에 내장된 데이터 처리 장치를 의미할 수 있다. 이와 같이 하드웨어에 내장된 데이터 처리 장치의 일 예로써, 마이크로프로세서(Microprocessor), 중앙처리장치(Central Processing Unit: CPU), 프로세서 코어(Processor Core), 멀티프로세서(Multiprocessor), ASIC(Application-Specific Integrated Circuit), FPGA(Field Programmable Gate Array) 등의 처리 장치를 망라할 수 있으나, 본 발명의 범위가 이에 한정되는 것은 아니다.
메모리(330)는 서비스 서버(300)가 처리하는 데이터를 일시적 또는 영구적으로 저장하는 기능을 수행한다. 메모리는 자기 저장 매체(Magnetic Storage Media) 또는 플래시 저장 매체(Flash Storage Media)를 포함할 수 있으나, 본 발명의 범위가 이에 한정되는 것은 아니다. 가령 메모리(330)는 학습된 인공 신경망을 구성하는 데이터들(가령 계수들)을 일시적 및/또는 영구적으로 저장할 수 있다. 물론 메모리(330)는 인공 신경망을 학습하기 위한 학습 데이터 또는 서비스 서버(300)로부터 수신된 데이터를 저장할 수도 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
제4 프로세서(340)는 전술한 제3 프로세서(320)의 제어에 따라 연산을 수행하는 장치를 의미할 수 있다. 이때 제4 프로세서(340)는 전술한 제3 프로세서(320)보다 높은 연산 능력을 갖는 장치일 수 있다. 가령 제4 프로세서(340)는 GPU(Graphics Processing Unit)로 구성될 수 있다. 다만 이는 예시적인 것으로 본 발명의 사상이 이에 한정되는 것은 아니다. 본 발명의 일 실시예에서, 제4 프로세서(340)는 복수일 수도 있고, 단수일 수도 있다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 사용자가 서버(100)에 의해 제공되는 다양한 서비스를 이용할 수 있도록 사용자와 서버(100)를 매개하는 다양한 형태의 장치를 의미할 수 있다. 바꾸어 말하면, 본 발명의 일 실시예에 따른 사용자 단말(200)은 서버(100)와 데이터를 송수신 하는 다양한 장치를 의미할 수 있다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 서버(100)에 의해 제공되는 립싱크 데이터를 수신하고, 이를 이용하여 출력 프레임을 생성할 수 있다. 이와 같은 사용자 단말(200)은 도 1에 도시된 바와 같이, 휴대용 단말(201, 202, 203)을 의미할 수도 있고, 컴퓨터(204)를 의미할 수도 있다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 상술한 기능을 수행하기 위해 콘텐츠 등을 표시하기 위한 표시수단, 이러한 콘텐츠에 대한 사용자의 입력을 획득하기 위한 입력수단을 구비할 수 있다. 이 때 입력수단 및 표시수단은 다양하게 구성될 수 있다. 가령 입력수단은 키보드, 마우스, 트랙볼, 마이크, 버튼, 터치패널 등을 포함할 수 있으나 이에 한정되지 않는다.
본 발명에서 이와 같은 사용자 단말(200)은 때때로 '립싱크 영상 표시 장치'로 명명되어 설명될 수 있다.
본 발명의 일 실시예에 따른 통신망(400)은 립싱크 영상 생성 시스템의 각 구성 간의 데이터 송수신을 매개하는 통신망을 의미할 수 있다. 가령 통신망(400)은 LANs(Local Area Networks), WANs(Wide Area Networks), MANs(Metropolitan Area Networks), ISDNs(Integrated Service Digital Networks) 등의 유선 네트워크나, 무선 LANs, CDMA, 블루투스, 위성 통신 등의 무선 네트워크를 망라할 수 있으나, 본 발명의 범위가 이에 한정되는 것은 아니다.
도 4 및 도 5는 본 발명의 일 실시예에 따른 서버(100)에 의해 학습된 인공 신경망의 예시적인 구조를 설명하기 위한 도면이다. 이하에서는 설명의 편의를 위하여 제1 인공 신경망 및 제2 인공 신경망을 '인공 신경망'으로 통칭하여 설명한다.
본 발명의 일 실시예에 따른 인공 신경망은 도 4에 도시된 바와 같은 합성 곱 신경망(CNN: Convolutional Neural Network) 모델에 따른 인공 신경망일 수 있다. 이때 CNN 모델은 복수의 연산 레이어(Convolutional Layer, Pooling Layer)를 번갈아 수행하여 최종적으로는 입력 데이터의 특징을 추출하는 데 사용되는 계층 모델일 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 학습 데이터를 지도학습(Supervised Learning) 기법에 따라 처리하여 인공 신경망 모델을 구축하거나 학습시킬 수 있다. 서버(100)가 인공 신경망을 학습시키는 방법에 대한 상세한 설명은 후술한다.
본 발명의 일 실시예에 따른 서버(100)는 복수의 학습 데이터를 이용하여, 어느 하나의 입력 데이터를 인공 신경망에 입력하여 생성된 출력 값이 해당 학습 데이터에 표지된 값에 근접하도록 각 레이어 및/또는 각 노드의 가중치를 갱신하는 과정을 반복하여 수행함으로써 인공 신경망을 학습시킬 수 있다.
이때 본 발명의 일 실시예에 따른 서버(100)는 역전파(Back Propagation) 알고리즘에 따라 각 레이어 및/또는 각 노드의 가중치(또는 계수)를 갱신할 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 입력 데이터의 특징 값을 추출하기 위한 컨볼루션 레이어(Convolution layer), 추출된 특징 값을 결합하여 특징 맵을 구성하는 풀링 레이어(pooling layer)를 생성할 수 있다.
또한 본 발명의 일 실시예에 따른 서버(100)는 생성된 특징 맵을 결합하여, 입력 데이터가 복수의 항목 각각에 해당할 확률을 결정할 준비를 하는 풀리 커넥티드 레이어(Fully Conected Layer)를 생성할 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 입력 데이터에 대응되는 출력을 포함하는 아웃풋 레이어(Output Layer)를 산출할 수 있다.
도 4에 도시된 예시에서는, 입력 데이터가 5X7 형태의 블록으로 나누어지며, 컨볼루션 레이어의 생성에 5X3 형태의 단위 블록이 사용되고, 풀링 레이어의 생성에 1X4 또는 1X2 형태의 단위 블록이 사용되는 것으로 도시되었지만, 이는 예시적인 것으로 본 발명의 사상이 이에 한정되는 것은 아니다. 따라서 입력 데이터의 종류 및/또는 각 블록의 크기는 다양하게 구성될 수 있다.
한편 이와 같은 인공 신경망은 전술한 메모리(130)에 인공 신경망의 모델의 종류, 인공 신경망을 구성하는 적어도 하나의 노드의 계수, 노드의 가중치 및 인공 신경망을 구성하는 복수의 레이어 간의 관계를 정의하는 함수의 계수들의 형태로 저장될 수 있다. 물론 인공 신경망의 구조 또한 메모리(130)에 소스코드 및/또는 프로그램의 형태로 저장될 수 있다.
본 발명의 일 실시예에 따른 인공 신경망은 도 5에 도시된 바와 같은 순환 신경망(Recurrent Neural Network, RNN) 모델에 따른 인공 신경망일 수 있다.
도 5를 참조하면, 이와 같은 순환 신경망(RNN) 모델에 따른 인공 신경망은 적어도 하나의 입력 노드(N1)를 포함하는 입력 레이어(L1), 복수의 히든 노드(N2)를 포함하는 히든 레이어(L2) 및 적어도 하나의 출력 노드(N3)를 포함하는 출력 레이어(L3)를 포함할 수 있다.
히든 레이어(L2)는 도시된 바와 같이 전체적으로 연결된(Fully Connected) 하나 이상의 레이어를 포함할 수 있다. 히든 레이어(L2)가 복수의 레이어를 포함하는 경우, 인공 신경망은 각각의 히든 레이어 사이의 관계를 정의하는 함수(미도시)를 포함할 수 있다.
출력 레이어(L3)의 적어도 하나의 출력 노드(N3)는 서버(100)의 제어에 따라 인공 신경망이 입력 레이어(L1)의 입력 값으로부터 생성한 출력 값을 포함할 수 있다.
한편 각 레이어의 각 노드에 포함되는 값은 벡터일 수 있다. 또한 각 노드는 해당 노드의 중요도에 대응되는 가중치를 포함할 수도 있다.
한편 인공 신경망은 입력 레이어(L1)와 히든 레이어(L2)의 관계를 정의하는 제1 함수(F1) 및 히든 레이어(L2)와 출력 레이어(L3)의 관계를 정의하는 제2 함수(F2)를 포함할 수 있다.
제1 함수(F1)는 입력 레이어(L1)에 포함되는 입력 노드(N1)와 히든 레이어(L2)에 포함되는 히든 노드(N2)간의 연결관계를 정의할 수 있다. 이와 유사하게, 제2 함수(F2)는 히든 레이어(L2)에 포함되는 히든 노드(N2)와 출력 레이어(L2)에 포함되는 출력 노드(N2)간의 연결관계를 정의할 수 있다.
이와 같은 제1 함수(F1), 제2 함수(F2) 및 히든 레이어 사이의 함수들은 이전 노드의 입력에 기초하여 결과물을 출력하는 순환 신경망 모델을 포함할 수 있다.
서버(100)에 의해 인공 신경망이 학습되는 과정에서, 복수의 학습 데이터에 기초하여 제1 함수(F1) 및 제2 함수(F2)가 학습될 수 있다. 물론 인공 신경망이 학습되는 과정에서 전술한 제1 함수(F1) 및 제2 함수(F2) 외에 복수의 히든 레이어 사이의 함수들 또한 학습될 수 있다.
본 발명의 일 실시예에 따른 인공 신경망은 표지(Labeled)된 학습 데이터를 기반으로 지도학습(Supervised Learning) 방식으로 학습될 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 복수의 학습 데이터를 이용하여, 어느 하나의 입력 데이터를 인공 신경망에 입력하여 생성된 출력 값이 해당 학습 데이터에 표지된 값에 근접하도록 전술한 함수들(F1, F2, 히든 레이어 사이의 함수들 등)을 갱신하는 과정을 반복하여 수행함으로써 인공 신경망을 학습시킬 수 있다.
이때 본 발명의 일 실시예에 따른 서버(100)는 역전파(Back Propagation) 알고리즘에 따라 전술한 함수들(F1, F2, 히든 레이어 사이의 함수들 등)을 갱신할 수 있다. 다만 이는 예시적인 것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
도 4 및 도 5에서 설명한 인공 신경망의 종류 및/또는 구조는 예시적인 것으로 본 발명의 사상이 이에 한정되는 것은 아니다. 따라서 다양한 종류의 모델의 인공 신경망이 명세서를 통하여 설명하는 '인공 신경망'에 해당할 수 있다.
이하에서는 서버(100)에 의해 수행되는 립싱크 영상 제공 방법과 사용자 단말(200)에 의해 수행되는 립싱크 영상 표시 방법을 중심으로 설명한다.
본 발명의 일 실시예에 따른 서버(100)는 각각의 학습 데이터를 이용하여 제1 인공 신경망 및 제2 인공 신경망을 학습시킬 수 있다.
도 6은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(510)를 이용하여 제1 인공 신경망(520)을 학습하는 방법을 설명하기 위한 도면이다. 도 7은 본 발명의 일 실시예에 따른 서버(100)가 학습된 제1 인공 신경망(520)을 이용하여 입술 이미지(543)를 출력하는 과정을 설명하기 위한 도면이다.
본 발명의 일 실시예에 따른 제1 인공 신경망(520)은 복수의 학습 데이터(510) 각각에 포함되는 제1 입술 이미지, 음성 및 제2 입술 이미지 간의 상관관계를 학습한(또는 학습하는) 신경망을 의미할 수 있다.
따라서 본 발명의 일 실시예에 따른 제1 인공 신경망(520)은 도 7에 도시된 바와 같이 음성(531)과 제1 입술 이미지(542)의 입력에 따라, 제1 입술 이미지(542)가 음성(531)에 따라 변형된 이미지인 제2 입술 이미지(543)를 출력하도록 학습된(또는 학습되는) 신경망을 의미할 수 있다. 이때 제1 입술 이미지(542)는 샘플 이미지로써, 음성에 따른 입술 이미지 생성에 기반이 되는 입술의 모양을 포함하는 이미지 일 수 있다.
본 발명의 일 실시예에 따른 복수의 학습 데이터(510) 각각은 제1 입술 이미지, 음성 및 제2 입술 이미지를 포함할 수 있다.
가령 첫 번째 학습 데이터(511)의 경우 제1 입술 이미지(511B), 음성(511A) 및 제2 입술 이미지(511C)를 포함할 수 있다. 이와 유사하게 두 번째 학습 데이터(512) 및 세 번째 학습 데이터(513)도 각각 제1 입술 이미지, 음성 및 제2 입술 이미지를 포함할 수 있다.
한편 본 발명의 일 실시예에서, 복수의 학습 데이터(510) 각각에 포함되는 제2 입술 이미지는 복수일 수도 있고 단수일 수도 있다. 가령 서버(100)가 음성을 소정의 규칙에 따라 분할하여 분할 된 음성 구간으로부터 입술 이미지를 생성하는 예시에서, 제2 입술 이미지는 단수일 수 있다. 이때 복수의 학습 데이터(510) 각각에 포함되는 음성 또한 전체 음성에서 분할된 일부 구간일 수 있다.
한편 서버(100)가 음성 전체로부터 일련의 입술 이미지들을 생성하는 예시에서, 제2 입술 이미지는 도 6에 도시된 바와 같이 복수일 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
도 8은 본 발명의 일 실시예에 따른 서버(100)가 복수의 학습 데이터(550)를 이용하여 제2 인공 신경망(560)을 학습하는 방법을 설명하기 위한 도면이다. 도 9는 본 발명의 일 실시예에 따른 서버(100)가 제2 인공 신경망(560)을 이용하여 대상 음성(580)을 생성하는 과정을 설명하기 위한 도면이다.
본 발명의 일 실시예에 따른 제2 인공 신경망(560)은 복수의 학습 데이터(550) 각각에 포함되는 텍스트와 해당 텍스트의 독음에 해당하는 대상 음성 간의 상관관계를 학습한(또는 학습하는) 신경망을 의미할 수 있다.
따라서 본 발명의 일 실시예에 따른 제2 인공 신경망(560)은 도 9에 도시된 바와 같이 텍스트(570)의 입력에 따라, 텍스트(570)의 독음에 해당하는 대상 음성(580)을 출력하도록 학습된(또는 학습되는) 신경망을 의미할 수 있다.
이때 복수의 학습 데이터(550) 각각은 텍스트와 해당 텍스트의 독음에 해당하는 대상 음성을 포함할 수 있다.
가령 첫 번째 학습 데이터(551)의 대상 음성(551A) 및 그에 따른 텍스트(551B)를 포함할 수 있다. 이와 유사하게 두 번째 학습 데이터(552) 및 세 번째 학습 데이터(553)도 각각 대상 음성과, 해당 대상 음성에 대응되는 텍스트를 포함할 수 있다.
이하에서는 도 6 내지 도 9에서 설명한 과정에 따라 제1 인공 신경망(520) 및 제2 인공 신경망(560)이 학습되었음을 전제로 설명한다.
도 10 및 도 11은 본 발명의 일 실시예에 따른 서버(100)에 의해 수행되는 립싱크 영상 제공 방법과 사용자 단말(200)에 의해 제공되는 립싱크 영상 표시 방법을 설명하기 위한 흐름도이다.
본 발명의 일 실시예에 따른 서버(100)는 적어도 하나의 프레임으로 구성되며 대상 객체를 묘사하는 탬플릿 영상을 획득할 수 있다.(S610)
본 발명에서 '탬플릿 영상'은 대상 객체를 묘사하는 영상으로, 대상체의 얼굴을 포함하는 영상일 수 있다. 가령 탬플릿 영상을 대상체의 상반신을 포함하는 영상일 수도 있고, 대상체의 전신을 포함하는 영상일 수도 있다.
한편 전술한 바와 같이 탬플릿 영상은 복수의 프레임으로 구성될 수 있다. 예를 들어 탬플릿 프레임은 초당 30프레임으로 구성되는 수초 길이의 영상일 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 일 실시예에 따른 서버(100)는 다른 장치로부터 탬플릿 영상을 수신하는 방식 또는 저장된 탬플릿 영상을 불러오는 방식으로 탬플릿 영상을 획득할 수 있다. 가령 서버(100)는 메모리(130)로부터 탬플릿 영상을 불러오는 방식으로 탬플릿 영상을 획득할 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 일 실시예에 따른 서버(100)는 대상 객체의 목소리로 사용 할 대상 음성을 획득할 수 있다.(S620)
본 발명에서 '대상 음성'은 출력 영상(출력 프레임으로 구성되는 영상)의 음향 신호로써 사용되는 것으로, 출력 프레임에서 표사하는 대상 객체의 입술 모양과 대응되는 음성을 의미할 수 있다.
전술한 탬플릿 영상과 마찬가지로, 서버(100)는 다른 장치로부터 대상 음성을 수신하는 방식 또는 저장된 대상 음성을 불러오는 방식으로 대상 음성을 획득할 수 있다. 가령 서버(100)는 메모리(130)로부터 대상 음성을 불러오는 방식으로 대상 음성을 획득할 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 선택적 실시예에서, 서버(100)는 학습된 제2 인공 신경망을 이용하여 텍스트로부터부터 대상 음성을 생성할 수 있다. 이때 제2 인공 신경망은 도 9에 도시된 바와 같이 텍스트(570)의 입력에 따라, 텍스트(570)의 독음에 해당하는 대상 음성(580)을 출력하도록 학습된(또는 학습되는) 신경망을 의미할 수 있다.
한편 '텍스트'는 서버(100)가 소정의 규칙이나 방식에 따라 생성한 것 일 수 있다. 가령 서버(100)가 사용자 단말(200)로부터 수신된 요청에 따른 응답을 제공하는 예시에서, 서버(100)는 제3 인공 신경망(미도시)을 이용하여 사용자 단말(200)로부터 수신된 요청에 대한 응답이 되는 텍스트를 생성할 수 있다.
한편 서버(100)가 미리 설정된 시나리오에 따른 응답(또는 영상)을 제공하는 예시에서, 서버(100)는 메모리로부터 텍스트를 독출할 수도 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 일 실시예에 따른 서버(100)는 단계 S610에서 획득된 탬플릿 영상과 단계 S620에서 획득된 대상 음성을 사용자 단말(200)에 전송할 수 있다.(S630) 이때 본 발명의 일 실시예에 따른 사용자 단말(200)은 단계 S630에서 수신한 탬플릿 영상과 대상 음성을 저장할 수 있다.(S631)
한편 사용자 단말(200)에 저장된 탬플릿 영상과 대상 음성은 이후 출력 영상(또는 출력 프레임)을 생성 및/또는 출력하는데 사용될 수 있으며, 이에 대한 상세한 설명은 후술한다.
본 발명의 일 실시예에 따른 서버(100)는 학습된 제1 인공 신경망을 이용하여 탬플릿 영상의 프레임 별로 음성에 대응되는 입술 이미지를 생성할 수 있다.
본 발명에서 '탬플릿 영상의 프레임 별로'와 같은 표현은 탬플릿 영상의 개별 프레임 마다 입술 이미지를 생성하는 것을 의미할 수 있다. 가령 본 발명의 일 실시예에 따른 서버(100)는 학습된 제1 인공 신경망을 이용하여 탬플릿 영상의 제1 프레임에 대응되는 입술 이미지를 생성할 수 있다. (S641)
제1 인공 신경망은 도 7에서 설명한 바와 같이 음성(531)과 제1 입술 이미지(542)의 입력에 따라, 제1 입술 이미지(542)가 음성에 따라 변형된 이미지인 제2 입술 이미지(543)를 출력하도록 학습된(또는 학습되는) 신경망을 의미할 수 있다.
본 발명의 일 실시예에서 서버(100)는 탬플릿 영상의 제1 프레임으로부터 획득된 제1 입술 이미지와 단계 S620에서 획득한 음성을 제1 인공 신경망에 입력하고, 그에 대한 출력 결과로써 제1 프레임에 대한 입술 이미지를 생성할 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 제1 립싱크 데이터를 생성할 수 있다.(S642) 이때 제1 립싱크 데이터는 입술 이미지에 사용된 탬플릿 영상의 프레임(즉 제1 프레임)의 식별 정보, 단계 S641에서 생성된 입술 이미지, 입술 이미지에 사용된 탬플릿 영상의 프레임(즉 제1 프레임)에서 입술 이미지의 위치정보를 포함할 수 있다. 이와 같은 제1 립싱크 데이터의 생성을 위해 본 발명의 일 실시예에 따른 서버(100)는 제1 프레임에서 입술의 위치를 확인하고, 확인된 위치에 기반하여 입술 이미지의 위치정보를 생성할 수 있다.
본 발명의 일 실시예에 따른 서버(100)는 단계 S642에서 생성한 제1 립싱크 데이터를 사용자 단말(200)에 전송할 수 있다.(S643) 이때 제1 립싱크 데이터는 전술한 바와 같이 입술 이미지에 사용된 탬플릿 영상의 프레임(즉 제1 프레임)의 식별 정보, 단계 S641에서 생성된 입술 이미지, 입술 이미지에 사용된 탬플릿 영상의 프레임(즉 제1 프레임)에서 입술 이미지의 위치정보를 포함할 수 있다.
이와 같은 제1 립싱크 데이터를 수신한 사용자 단말(200)은 제1 립싱크 데이터에 포함된 제1 프레임의 식별 정보를 참조하여, 메모리로부터 프레임 식별 정보에 상응하는 프레임을 리드할 수 있다.(S644) 이때 사용자 단말(200)은 단계 S631에서 저장한 탬플릿 영상으로부터 프레임 식별 정보에 상응하는 프레임을 검색하여 리드할 수 있다.
또한 사용자 단말(200)은 제1 립싱크 데이터에 포함된 입술 이미지의 위치정보에 기반하여, 단계 S644에서 리드 된 프레임 상에 제1 립싱크 데이터에 포함된 입술 이미지를 오버랩 시켜 출력 프레임을 생성하고(S645), 이를 표시할 수 있다.(S646) 상술한 S641 내지 S646 단계들(FR1)은 하나의 프레임인 제1 프레임에 대한 서버(100) 및 사용자 단말(200)의 처리 과정을 설명하기 위한 단계들이다.
본 발명의 일 실시예에 따른 서버(100)는 복수의 탬플릿 영상 프레임에 대해서, 프레임 단위로 상기 립싱크 데이터를 생성할 수 있다. 이때 사용자 단말(200)은 프레임 단위로 생성된 립싱크 데이터를 수신하고, 립싱크 데이터 별로 출력 프레임을 생성할 수 있다.
가령 서버(100) 및 사용자 단말(200)은 S651 내지 S656 단계들(FR2)에 따라 제2 프레임을 상술한 제1 프레임과 마찬가지 방식으로 처리할 수 있다. 이때 제2 프레임은 탬플릿 영상에서 제1 프레임에 후행하는 프레임일 수 있다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 상술한 과정에 따라 생성된 출력 프레임들을 표시함과 동시에 단계 S631에서 저장한 대상 음성을 재생함으로써 객체가 해당 음성으로 말하는 것과 같은 출력 결과를 사용자에게 제공할 수 있다. 즉 사용자 단말(200)은 출력 객체의 영상은 입모양이 서버(100)로부터 수신된 입모양으로 변경된 출력 프레임으로써, 출격 객체의 음성은 서버(100)로부터 수신된 대상 음성으로써 제공하여 자연스러운 립싱크 영상을 제공할 수 있다.
도 12는 본 발명의 일 실시예에 따른 사용자 단말(200)이 출력 프레임을 생성하는 방법을 설명하기 위한 도면이다.
전술한 바와 같이 탬플릿 영상은 적어도 하나의 프레임으로 구성되며, 서버(100) 및 사용자 단말(200)은 탬플릿 영상을 구성하는 각각의 프레임에 대해 출력 프레임을 생성할 수 있다. 따라서 사용자 단말(200) 입장에서 출력 프레임의 집합은 출력 영상(710)에 해당할 수 있다.
한편 출력 영상(710)을 구성하는 개별 출력 프레임(711)을 생성하는 과정을 살펴보면, 사용자 단말(200)은 탬플릿 영상의 특정 프레임(590) 상에 서버(100)에 의해 생성된 입술 이미지(544)를 오버랩 하여 출력 프레임(711)을 생성할 수 있다. 이때 사용자 단말(200)은 서버(100)로부터 수신된 입술 이미지의 위치 정보(591)를 이용하여 탬플릿 영상의 특정 프레임(590) 상에서의 입술 이미지(544)의 오버랩 위치를 결정할 수 있다.
이하에서는 다시 도 10 내지 도 11을 참조하여 사용자 단말(200)에 의해 수행되는 립싱크 영상 표시 방법을 설명한다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 서버(100)로부터 탬플릿 영상 및 대상 객체의 목소리로 사용 할 대상 음성을 수신하여(S630) 저장할 수 있다.(S631) 이를 위해 본 발명의 일 실시예에 따른 서버(100)는 탬플릿 영상 및 대상 음성을 사전에 획득 및/또는 생성할 수 있으며, 이에 대해서는 단계 S610 내지 S620에서 설명하였다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 프레임 별로 생성된 립싱크 데이터를 수신할 수 있다. 이때 립싱크 데이터는 탬플릿 영상 내 프레임 식별 정보, 입술 이미지, 상기 탬플릿 영상 내 프레임에서 상기 입술 이미지의 위치정보를 포함할 수 있다.
가령 사용자 단말(200)은 제1 프레임에 대한 립싱크 데이터인 제1 립싱크 데이터를 수신하고(S643), 이와 유사하게 제2 프레임에 대한 립싱크 데이터인 제2 립승크 데이터를 수신(S653)할 수 있다.
본 발명의 일 실시예에 따른 사용자 단말(200)은 단계 S630에서 수신된 탬플릿 영상 및 대상 음성과 단계 S643, S653에서 수신된 립싱크 데이터를 이용하여 립싱크 영상을 표시할 수 있다.
가령 사용자 단말(200)은 단계 S643에서 수신한 제1 립싱크 데이터에 포함된 제1 프레임의 식별 정보를 참조하여, 메모리로부터 프레임 식별 정보에 상응하는 프레임을 리드할 수 있다.(S644) 이때 사용자 단말(200)은 단계 S631에서 저장한 탬플릿 영상으로부터 프레임 식별 정보에 상응하는 프레임을 검색하여 리드할 수 있다.
또한 사용자 단말(200)은 제1 립싱크 데이터에 포함된 입술 이미지의 위치정보에 기반하여, 단계 S644에서 리드 된 프레임 상에 제1 립싱크 데이터에 포함된 입술 이미지를 오버랩 시켜 출력 프레임을 생성하고(S645), 이를 표시할 수 있다.(S646)
사용자 단말(200)은 이와 마찬가지 방식으로 단계 S656에서 제2 립싱크 데이터에 기초하여 생성된 출력 프레임을 표시할 수 있다.
물론 사용자 단말(200)은 상술한 방식으로 복수의 출력 프레임을 생성하고 이를 표시할 수 있다. 바꾸어말하면 사용자 단말(200)은 대상 음성의 흐름에 따른 복수의 립싱크 데이터를 수신하고, 복수의 립싱크 데이터 각각으로부터 생성된 출력 프레임을 시간의 흐름에 따라 순차적으로 표시할 수 있다.
도 13은 본 발명의 다른 실시예에 따른 서버(100)가 제1 인공 신경망의 학습을 위한 학습 데이터를 생성하는 과정을 설명하기 위한 도면이다. 도 14는 본 발명의 다른 실시예에 따른 서버(100)가 생성한 학습 데이터(850)의 예시이다.
본 발명의 다른 실시예에 따른 서버(100)는 학습 객체의 발화 구간(Sec A)을 포함하는 제1 영상(800)으로부터 학습 데이터(850)를 생성할 수 있다.
본 발명에서 '학습 객체'는 학습을 위한 영상에 포함되는 객체로 가령 사람의 형상을 갖는 객체일 수 있다.
한편 '학습 객체의 발화 구간(Sec A)'은 전체 영상(예를 들어 제1 영상(800))에서 학습 객체에 의해 발화가 이루어지는 시구간을 의미하는 것으로 예를 들어 제1 영상(800)의 2.37초부터 3.58초까지의 형태로 정의될 수 있다. 이와 같은 학습 객체의 발화 구간(Sec A)은 동일한 영상 내에서 복수일 수도 있으며, 학습 객체의 발화 구간(Sec A)이 복수인 경우 각각의 구간에 대해서 후술하는 과정에 따라 학습 데이터가 생성될 수 있다.
본 발명에서 '제1 영상'(800)은 이미지(또는 프레임)(810)와 음성(820)으로 구성되는 멀티미디어 개체를 의미할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 제1 영상(800)으로부터 학습 객체의 입술의 형상을 포함하는 제1 데이터(851)를 생성할 수 있다. 가령 서버(100)는 제1 영상(800)을 구성하는 복수의 프레임(810) 중 특정 조건을 만족하는 프레임으로부터 학습 객체의 입술 형상을 포함하는 제1 데이터(851)를 생성할 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 다른 실시예에 따른 서버(100)는 발화 음성을 포함하는 제2 데이터(852)를 생성할 수 있다. 이때 발화 음성은 제1 영상(800)의 학습 객체의 발화 구간(Sec A)을 구성하는 음성(821)에 해당할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 적어도 하나의 음성 관련 이미지(853) 및 적어도 하나의 음성 무관 이미지(854)를 병합한 제3 데이터(855)를 생성할 수 있다. 이때 적어도 하나의 음성 관련 이미지는(853) 제1 영상(800)의 학습 객체의 발화 구간(Sec A)을 구성하는 적어도 하나의 프레임(811)에 해당할 수 있다. 또한 적어도 하나의 음성 무관 이미지(854)는 제1 영상(800)의 학습 객체의 발화 구간(Sec A)과 상이한 구간(Sec B)을 구성하는 적어도 하나의 프레임(812)에 해당할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 다양한 방식으로 제1 영상(800)에서 상이한 구간(Sec B)을 선택할 수 있다. 가령 서버(100)는 제1 영상(800)에서 학습 객체의 발화 구간(Sec A) 직전의 소정의 길이에 해당하는 구간 또는 직후의 소정의 길이에 해당하는 구간을 상이한 구간(Sec B)으로 선택할 수 있다. 이때 서버(100)는 제1 영상(800)에서 학습 객체의 발화 여부와 무관하게 상이한 구간(Sec B)을 선택할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 상술한 과정에 따라 생성된 제1 데이터(851), 제2 데이터(852) 및 제3 데이터(855)를 포함하는 학습 데이터(850)를 생성할 수 있다. 이때 서버(100)는 제1 영상(800)에 포함되는 복수의 발화 구간 각각으로부터 학습 데이터를 생성할 수도 있으며, 이에 따라 복수개의 학습 데이터가 생성될 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 상술한 과정에 따라 생성된 학습 데이터에 기초하여 제1 인공 신경망을 학습시킬 수 있다.
도 15는 제1 인공 신경망(520)을 설명하기 위한 도면이다.
본 발명의 다른 실시예에 따른 제1 인공 신경망(520)은 제1 데이터(831), 제2 데이터(832) 및 제3 데이터(833) 간의 상관관계를 학습한 신경망일 수 있다. 이에 따라 제1 인공 신경망(520)은 제1 데이터(831) 및 제2 데이터(832)의 입력에 따라 제3 데이터(833)를 출력할 수 있다.
바꾸어말하면 본 발명의 다른 실시예에 따른 제1 인공 신경망(520)은 음성과 입술의 형상을 포함하는 적어도 하나의 제1 이미지의 입력에 따라 제1 이미지에 포함된 입술의 형상이 입력된 음성에 따라 변형된 이미지인 제2 이미지를 출력할 수 있다.
이때 제1 인공 신경망(520)으로부터 출력되는 제3 데이터(833)는 대상 객체의 발화에 따른 입모양을 포함하는 음성 관련 이미지(834) 및 대상 객체의 발화에 따른 입모양을 제외한 나머지 형상을 제공하는 음성 무관 이미지(835)를 포함할 수 있다.
도 16은 본 발명의 일 실시예에 따른 제3 데이터(833)의 음성 무관 이미지(835)를 설명하기 위한 도면이다.
본 발명의 다른 실시예에서, 제3 데이터(833)의 음성 무관 이미지(835)는 대상 객체의 발화에 따른 입모양(841)을 제외한 나머지 형상(842)을 제공하는 데이터 일 수 있다. 이때 '나머지 형상'은 가령 대상 객체의 입 주변부 형상, 대상 객체의 치아의 형상, 대상 객체의 얼굴의 주름 패턴, 대상 객체의 피부 색상, 대상 객체의 턱 모양, 대상 객체의 목 모양 및 대상 객체의 의상 색상 중 적어도 어느 하나를 포함할 수 있다.
따라서 본 발명의 다른 실시예에 따른 서버(100)는 음성 관련 이미지(834)로부터 발화에 따른 입모양을 생성하되, 음성 무관 이미지(835)를 참조하여 입 주변부의 형상을 생성할 수 있다. 예를 들어 서버(100)는 입 모양과 관련해서는 음성 관련 이미지(834)를 주로 따르되, 그 외의 형상에 대해서는 음성 무관 이미지(835)를 따라 출력 이미지를 생성할 수 있다.
한편 본 명세서에서는 '음성 무관 이미지(835)'가 '이미지'의 형태인 것을 전제하여 설명하였지만, 이는 설명의 편의를 위한 것으로 음성 무관 이미지(835)는 그 명칭에도 불구하고 다양한 형태의 데이터 일 수 있다. 가령 음성 무관 이미지(835)는 입 주변부의 특징을 수치의 형태로 포함하는 벡터(Vector)일 수도 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
이와 같이 본 발명은 음성과 관련 있는 이미지 외에, 그와 무관한 이미지까지 함께 학습함으로써 보다 자연스러운 발화 영상을 생성할 수 있도록 한다.
도 17은 본 발명의 다른 실시예에 따른 서버(100)에 의해 제1 인공 신경망이 학습되는 과정을 설명하기 위한 흐름도이다. 이하에서는 도 13 내지 도 15를 함께 참조하여 설명한다.
도 13은 본 발명의 다른 실시예에 따른 서버(100)가 제1 인공 신경망의 학습을 위한 학습 데이터를 생성하는 과정을 설명하기 위한 도면이다. 도 14는 본 발명의 다른 실시예에 따른 서버(100)가 생성한 학습 데이터(850)의 예시이다.
본 발명의 다른 실시예에 따른 서버(100)는 학습 객체의 발화 구간(Sec A)을 포함하는 제1 영상(800)으로부터 학습 데이터(850)를 생성할 수 있다.(S1510)
본 발명에서 '학습 객체'는 학습을 위한 영상에 포함되는 객체로 가령 사람의 형상을 갖는 객체일 수 있다.
한편 '학습 객체의 발화 구간(Sec A)'은 전체 영상(예를 들어 제1 영상(800))에서 학습 객체에 의해 발화가 이루어지는 시구간을 의미하는 것으로 예를 들어 제1 영상(800)의 2.37초부터 3.58초까지의 형태로 정의될 수 있다. 이와 같은 학습 객체의 발화 구간(Sec A)은 동일한 영상 내에서 복수일 수도 있으며, 학습 객체의 발화 구간(Sec A)이 복수인 경우 각각의 구간에 대해서 후술하는 과정에 따라 학습 데이터가 생성될 수 있다.
본 발명에서 '제1 영상'(800)은 이미지(또는 프레임)(810)와 음성(820)으로 구성되는 멀티미디어 개체를 의미할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 제1 영상(800)으로부터 학습 객체의 입술의 형상을 포함하는 제1 데이터(851)를 생성할 수 있다. (S1511) 가령 서버(100)는 제1 영상(800)을 구성하는 복수의 프레임(810) 중 특정 조건을 만족하는 프레임으로부터 학습 객체의 입술 형상을 포함하는 제1 데이터(851)를 생성할 수 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
본 발명의 다른 실시예에 따른 서버(100)는 발화 음성을 포함하는 제2 데이터(852)를 생성할 수 있다.(S1512) 이때 발화 음성은 제1 영상(800)의 학습 객체의 발화 구간(Sec A)을 구성하는 음성(821)에 해당할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 적어도 하나의 음성 관련 이미지(853) 및 적어도 하나의 음성 무관 이미지(854)를 병합한 제3 데이터(855)를 생성할 수 있다.(S1513) 이때 적어도 하나의 음성 관련 이미지는(853) 제1 영상(800)의 학습 객체의 발화 구간(Sec A)을 구성하는 적어도 하나의 프레임(811)에 해당할 수 있다. 또한 적어도 하나의 음성 무관 이미지(854)는 제1 영상(800)의 학습 객체의 발화 구간(Sec A)과 상이한 구간(Sec B)을 구성하는 적어도 하나의 프레임(812)에 해당할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 다양한 방식으로 제1 영상(800)에서 상이한 구간(Sec B)을 선택할 수 있다. 가령 서버(100)는 제1 영상(800)에서 학습 객체의 발화 구간(Sec A) 직전의 소정의 길이에 해당하는 구간 또는 직후의 소정의 길이에 해당하는 구간을 상이한 구간(Sec B)으로 선택할 수 있다. 이때 서버(100)는 제1 영상(800)에서 학습 객체의 발화 여부와 무관하게 상이한 구간(Sec B)을 선택할 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 상술한 과정에 따라 생성된 제1 데이터(851), 제2 데이터(852) 및 제3 데이터(855)를 포함하는 학습 데이터(850)를 생성할 수 있다. 이때 서버(100)는 제1 영상(800)에 포함되는 복수의 발화 구간 각각으로부터 학습 데이터를 생성할 수도 있으며, 이에 따라 복수개의 학습 데이터가 생성될 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 상술한 과정에 따라 생성된 학습 데이터에 기초하여 제1 인공 신경망을 학습시킬 수 있다.(S1520)
도 15는 제1 인공 신경망(520)을 설명하기 위한 도면이다.
본 발명의 다른 실시예에 따른 제1 인공 신경망(520)은 제1 데이터(831), 제2 데이터(832) 및 제3 데이터(833) 간의 상관관계를 학습한 신경망일 수 있다.
본 발명의 다른 실시예에 따른 서버(100)는 제1 데이터(831) 및 제2 데이터(832)의 입력에 따라 제3 데이터(833)를 출력하도록 제1 인공 신경망(520)을 학습시킬 수 있다.(S1521) 가령 서버(100)는 전술한 과정에 따라 생성된 학습 데이터들을 이용하여 상술한 바와 같이 제1 인공 신경망(520)을 학습시킬 수 있다.
이때 제1 인공 신경망(520)으로부터 출력되는 제3 데이터(833)는 대상 객체의 발화에 따른 입모양을 포함하는 음성 관련 이미지(834) 및 대상 객체의 발화에 따른 입모양을 제외한 나머지 형상을 제공하는 음성 무관 이미지(835)를 포함할 수 있다.
도 16은 본 발명의 일 실시예에 따른 제3 데이터(833)의 음성 무관 이미지(835)를 설명하기 위한 도면이다.
본 발명의 다른 실시예에서, 제3 데이터(833)의 음성 무관 이미지(835)는 대상 객체의 발화에 따른 입모양(841)을 제외한 나머지 형상(842)을 제공하는 데이터 일 수 있다. 이때 '나머지 형상'은 가령 대상 객체의 입 주변부 형상, 대상 객체의 치아의 형상, 대상 객체의 얼굴의 주름 패턴, 대상 객체의 피부 색상, 대상 객체의 턱 모양, 대상 객체의 목 모양 및 대상 객체의 의상 색상 중 적어도 어느 하나를 포함할 수 있다.
따라서 본 발명의 다른 실시예에 따른 서버(100)는 음성 관련 이미지(834)로부터 발화에 따른 입모양을 생성하되, 음성 무관 이미지(835)를 참조하여 입 주변부의 형상을 생성할 수 있다. 예를 들어 서버(100)는 입 모양과 관련해서는 음성 관련 이미지(834)를 주로 따르되, 그 외의 형상에 대해서는 음성 무관 이미지(835)를 따라 출력 이미지를 생성할 수 있다.
한편 본 명세서에서는 '음성 무관 이미지(835)'가 '이미지'의 형태인 것을 전제하여 설명하였지만, 이는 설명의 편의를 위한 것으로 음성 무관 이미지(835)는 그 명칭에도 불구하고 다양한 형태의 데이터 일 수 있다. 가령 음성 무관 이미지(835)는 입 주변부의 특징을 수치의 형태로 포함하는 벡터(Vector)일 수도 있다. 다만 이는 예시적인것으로 본 발명의 사상이 이에 한정되는 것은 아니다.
이와 같이 본 발명은 음성과 관련 있는 이미지 외에, 그와 무관한 이미지까지 함께 학습함으로써 보다 자연스러운 발화 영상을 생성할 수 있도록 한다.
이상 설명된 본 발명에 따른 실시예는 컴퓨터 상에서 다양한 구성요소를 통하여 실행될 수 있는 컴퓨터 프로그램의 형태로 구현될 수 있으며, 이와 같은 컴퓨터 프로그램은 컴퓨터로 판독 가능한 매체에 기록될 수 있다. 이때, 매체는 컴퓨터로 실행 가능한 프로그램을 저장하는 것일 수 있다. 매체의 예시로는, 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체, CD-ROM 및 DVD와 같은 광기록 매체, 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical medium), 및 ROM, RAM, 플래시 메모리 등을 포함하여 프로그램 명령어가 저장되도록 구성된 것이 있을 수 있다.
한편, 상기 컴퓨터 프로그램은 본 발명을 위하여 특별히 설계되고 구성된 것이거나 컴퓨터 소프트웨어 분야의 당업자에게 공지되어 사용 가능한 것일 수 있다. 컴퓨터 프로그램의 예에는, 컴파일러에 의하여 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용하여 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드도 포함될 수 있다.
본 발명에서 설명하는 특정 실행들은 일 실시 예들로서, 어떠한 방법으로도 본 발명의 범위를 한정하는 것은 아니다. 명세서의 간결함을 위하여, 종래 전자적인 구성들, 제어 시스템들, 소프트웨어, 상기 시스템들의 다른 기능적인 측면들의 기재는 생략될 수 있다. 또한, 도면에 도시된 구성 요소들 간의 선들의 연결 또는 연결 부재들은 기능적인 연결 및/또는 물리적 또는 회로적 연결들을 예시적으로 나타낸 것으로서, 실제 장치에서는 대체 가능하거나 추가의 다양한 기능적인 연결, 물리적인 연결, 또는 회로 연결들로서 나타내어질 수 있다. 또한, "필수적인", "중요하게" 등과 같이 구체적인 언급이 없다면 본 발명의 적용을 위하여 반드시 필요한 구성 요소가 아닐 수 있다.
따라서, 본 발명의 사상은 상기 설명된 실시예에 국한되어 정해져서는 아니 되며, 후술하는 특허청구범위뿐만 아니라 이 특허청구범위와 균등한 또는 이로부터 등가적으로 변경된 모든 범위는 본 발명의 사상의 범주에 속한다고 할 것이다.
100: 서버
110: 통신부
120: 제1 프로세서
130: 메모리
140: 제2 프로세서
200: 사용자 단말
300: 서비스 서버
310: 통신부
320: 제3 프로세서
330: 메모리
340: 제4 프로세서
400: 통신망
110: 통신부
120: 제1 프로세서
130: 메모리
140: 제2 프로세서
200: 사용자 단말
300: 서비스 서버
310: 통신부
320: 제3 프로세서
330: 메모리
340: 제4 프로세서
400: 통신망
Claims (9)
- 컴퓨팅 장치가 입력된 음성과 동기화된 입술 모양을 생성하는 인공 신경망을 학습하는 방법에 있어서,
학습 객체의 발화 구간을 포함하는 제1 영상으로부터 학습 데이터를 생성하는 단계로써, 상기 학습 데이터는 상기 발화 구간에서의 발화 음성, 상기 발화 구간을 구성하는 적어도 하나의 음성 관련 이미지 및 상기 발화 구간과 상이한 구간을 구성하는 적어도 하나의 음성 무관 이미지를 포함하고, 상기 음성 무관 이미지는 상기 학습 객체의 발화에 따른 입모양을 제외한 나머지 형상을 제공하는 이미지이고; 및
상기 학습 데이터에 기초하여, 음성 및 입술의 형상을 포함하는 적어도 하나의 제1 이미지의 입력에 따라 상기 제1 이미지에 포함된 입술의 형상이 상기 음성에 따라 변형된 이미지인 제2 이미지를 출력하는 제1 인공 신경망을 학습하는 단계;를 포함하는, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 청구항 1에 있어서
상기 학습 데이터를 생성하는 단계는
상기 제1 영상으로부터 상기 학습 객체의 입술의 형상을 포함하는 제1 데이터를 생성하는 단계;
상기 발화 음성을 포함하는 제2 데이터를 생성하는 단계; 및
상기 적어도 하나의 음성 관련 이미지 및 상기 적어도 하나의 음성 무관 이미지를 병합한 제3 데이터를 생성하는 단계;를 포함하고,
상기 제1 데이터, 상기 제2 데이터 및 상기 제3 데이터는 상기 학습 데이터를 구성하는 데이터인, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 청구항 2에 있어서
상기 제1 인공 신경망은 상기 제1 데이터, 상기 제2 데이터 및 상기 제3 데이터 간의 상관관계를 학습한 신경망인, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 청구항 2에 있어서
상기 제1 인공 신경망을 학습하는 단계는
상기 제1 인공 신경망에 상기 제1 데이터 및 상기 제2 데이터의 입력에 따라 상기 제3 데이터가 출력되도록 상기 제1 인공 신경망을 학습시키는 단계;를 포함하는, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 청구항 4에 있어서
상기 제3 데이터의 상기 음성 무관 이미지에 해당하는 데이터는 상기 학습 객체의 발화에 따른 입모양을 제외한 나머지 형상을 제공하는 데이터인, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 청구항 5에 있어서
상기 나머지 형상은
상기 학습 객체의 입 주변부 형상, 상기 학습 객체의 치아의 형상, 상기 학습 객체의 얼굴의 주름 패턴, 상기 학습 객체의 피부 색상, 상기 학습 객체의 턱 모양, 상기 학습 객체의 목 모양 및 상기 학습 객체의 의상 색상 중 적어도 어느 하나를 포함하는, 립싱크 영상 생성을 위한 인공 신경망 학습 방법. - 컴퓨팅 장치가 음성과 입술 모양이 동기화된 영상을 제공하는 립싱크 영상을 제공하는 방법에 있어서,
적어도 하나의 프레임으로 구성되며 대상 객체를 묘사하는 탬플릿 영상을 획득하는 단계;
상기 대상 객체의 목소리로 사용 할 대상 음성을 획득하는 단계; 및
학습 된 제1 인공 신경망을 이용하여, 상기 탬플릿 영상의 프레임 별로 상기 음성에 대응되는 이미지를 생성하는 단계;를 포함하고,
상기 제1 인공 신경망은
상기 대상 객체의 입술의 형상을 포함하는 제1 데이터, 상기 대상 음성을 포함하는 제2 데이터의 입력에 따라 상기 대상 객체의 발화에 따른 입모양과 상기 대상 객체의 입모양을 제외한 나머지 형상을 포함하는 제3 데이터를 출력하는 신경망이고, 상기 제3 데이터는 상기 대상 음성과 관련된 이미지 및 상기 대상 음성과 무관한 이미지를 병합한 데이터인, 립싱크 영상 제공 방법. - 삭제
- 컴퓨터를 이용하여
청구항 1 내지 청구항 7 중 어느 한 항의 방법을 실행하기 위해 기록매체에 저장된 컴퓨터 프로그램.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020210164873A KR102558530B1 (ko) | 2021-11-25 | 2021-11-25 | 립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020210164873A KR102558530B1 (ko) | 2021-11-25 | 2021-11-25 | 립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20230077520A KR20230077520A (ko) | 2023-06-01 |
KR102558530B1 true KR102558530B1 (ko) | 2023-07-24 |
Family
ID=86771027
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020210164873A KR102558530B1 (ko) | 2021-11-25 | 2021-11-25 | 립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR102558530B1 (ko) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102700466B1 (ko) * | 2024-03-11 | 2024-08-30 | (주)비디오몬스터 | 멀티 카메라 촬영 영상 소스의 자동 동기화 편집 장치 및 방법 |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020184100A (ja) * | 2019-04-26 | 2020-11-12 | 株式会社スクウェア・エニックス | 情報処理プログラム、情報処理装置、情報処理方法及び学習済モデル生成方法 |
-
2021
- 2021-11-25 KR KR1020210164873A patent/KR102558530B1/ko active IP Right Grant
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020184100A (ja) * | 2019-04-26 | 2020-11-12 | 株式会社スクウェア・エニックス | 情報処理プログラム、情報処理装置、情報処理方法及び学習済モデル生成方法 |
Non-Patent Citations (1)
Title |
---|
SUPASORN SUWAJANAKORN et al., ‘Synthesizing Obama: Learning Lip Sync from Audio’, ACM Transactions on Graphics, Vol. 36, No. 4, Article 95. Publication date: July 2017.* |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102700466B1 (ko) * | 2024-03-11 | 2024-08-30 | (주)비디오몬스터 | 멀티 카메라 촬영 영상 소스의 자동 동기화 편집 장치 및 방법 |
Also Published As
Publication number | Publication date |
---|---|
KR20230077520A (ko) | 2023-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2022116977A1 (zh) | 目标对象的动作驱动方法、装置、设备及存储介质及计算机程序产品 | |
KR102346046B1 (ko) | 3차원 가상 인물 입모양 변화 제어 방법 및 장치 | |
US11514634B2 (en) | Personalized speech-to-video with three-dimensional (3D) skeleton regularization and expressive body poses | |
KR102360839B1 (ko) | 머신 러닝 기반의 발화 동영상 생성 방법 및 장치 | |
CN112100436B (zh) | 舞蹈片段识别方法、舞蹈片段识别装置和存储介质 | |
WO2019019935A1 (zh) | 交互方法、交互终端、存储介质和计算机设备 | |
US20230215068A1 (en) | Method for outputting blend shape value, storage medium, and electronic device | |
CN113299312B (zh) | 一种图像生成方法、装置、设备以及存储介质 | |
CN114495927A (zh) | 多模态交互的虚拟数字人的生成方法及装置、存储介质、终端 | |
EP4030421A1 (en) | Method for converting voice feature of voice | |
KR102373608B1 (ko) | 디지털 휴먼 영상 형성을 위한 전자 장치 및 방법과, 그를 수행하도록 컴퓨터 판독 가능한 기록 매체에 저장된 프로그램 | |
KR102190988B1 (ko) | 개별 화자 별 음성 제공 방법 및 컴퓨터 프로그램 | |
CN114356084A (zh) | 图像处理方法、系统及电子设备 | |
KR102558530B1 (ko) | 립싱크 영상 생성을 위한 인공 신경망 학습 방법 및 컴퓨터 프로그램 | |
CN115937369A (zh) | 一种表情动画生成方法、系统、电子设备及存储介质 | |
KR102190986B1 (ko) | 개별 화자 별 음성 생성 방법 | |
CN113282791B (zh) | 视频生成方法和装置 | |
CN115376482A (zh) | 面部动作视频生成方法及装置、可读介质和电子设备 | |
KR102563348B1 (ko) | 립싱크 영상 제공 장치, 방법 및 컴퓨터 프로그램과 립싱크 영상 표시 장치, 방법 및 컴퓨터 프로그램 | |
US20230023102A1 (en) | Apparatus, method, and computer program for providing lip-sync video and apparatus, method, and computer program for displaying lip-sync video | |
CN116958343A (zh) | 面部动画生成方法、装置、设备、介质及程序产品 | |
CN116485961A (zh) | 一种手语动画生成方法、设备和介质 | |
KR102514580B1 (ko) | 영상 전환 방법, 장치 및 컴퓨터 프로그램 | |
CN115640611A (zh) | 一种自然语言处理模型的更新方法及相关设备 | |
KR102190989B1 (ko) | 동시 발화 구간에서의 음성 생성 방법 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant |