KR20210156470A - 전자 장치 및 이의 제어 방법 - Google Patents

전자 장치 및 이의 제어 방법 Download PDF

Info

Publication number
KR20210156470A
KR20210156470A KR1020200074103A KR20200074103A KR20210156470A KR 20210156470 A KR20210156470 A KR 20210156470A KR 1020200074103 A KR1020200074103 A KR 1020200074103A KR 20200074103 A KR20200074103 A KR 20200074103A KR 20210156470 A KR20210156470 A KR 20210156470A
Authority
KR
South Korea
Prior art keywords
image
data
attribute value
attribute
image data
Prior art date
Application number
KR1020200074103A
Other languages
English (en)
Inventor
이한빛
이상구
유강민
Original Assignee
삼성전자주식회사
서울대학교산학협력단
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 삼성전자주식회사, 서울대학교산학협력단 filed Critical 삼성전자주식회사
Priority to KR1020200074103A priority Critical patent/KR20210156470A/ko
Priority to PCT/KR2021/005652 priority patent/WO2021256702A1/ko
Publication of KR20210156470A publication Critical patent/KR20210156470A/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/60Editing figures and text; Combining figures or text
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/04Architecture, e.g. interconnection topology
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/04Architecture, e.g. interconnection topology
    • G06N3/045Combinations of networks
    • G06N3/0454
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/08Learning methods
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20084Artificial neural networks [ANN]

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Biophysics (AREA)
  • Evolutionary Computation (AREA)
  • Artificial Intelligence (AREA)
  • Biomedical Technology (AREA)
  • Health & Medical Sciences (AREA)
  • Computational Linguistics (AREA)
  • Data Mining & Analysis (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Molecular Biology (AREA)
  • Computing Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Image Analysis (AREA)

Abstract

전자 장치가 개시된다. 본 개시에 따른 전자 장치는, 기생성된 잠재 공간에 관한 정보가 저장된 메모리, 및 이미지를 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 잠재 공간 상의 이미지 데이터로 변환하고, 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하며, 이미지 데이터 및 속성 변환 데이터를 기초로, 이미지 데이터에 대한 변환 이미지 데이터를 생성하고, 변환 이미지 데이터를 기초로 입력 이미지에 대한 변환 이미지를 생성하는 프로세서를 포함한다. 이때, 속성 변환 데이터 및 변환 이미지 데이터는 잠재 공간 상의 데이터이다.

Description

전자 장치 및 이의 제어 방법 { ELECTRONIC APPARATUS AND CONTROLLING METHOD THEREOF }
본 개시는 전자 장치 및 이의 제어 방법에 관한 것으로, 구체적으로는 이미지에 대한 변환 이미지를 생성하는 전자 장치 및 이의 제어 방법에 관한 것이다.
최근 인공지능 기술이 발달함에 따라 다양한 기술분야에서 인공지능 기술이 활용되고 있다. 이와 관련하여, 최근에는 GAN (Generative Adversarial Network) 네트워크의 등장으로 이미지 간 변환(Image to image to translation) 기술이 등장하고 있다.
이미지 간 변환 기술은 이미지의 배경 또는 객체의 색, 형상, 모양, 나이, 성별과 같은 다양한 이미지의 속성을 변환하여, 원래의 이미지의 일부 속성을 변환한 이미지를 생성하는 기술이다.
종래에는 GAN 네트워크를 포함하는 인공지능 모델은 입력된 이미지의 다양한 속성을 학습하고, 다양한 속성 중 적어도 하나의 속성을 변환한 이미지를 출력하도록 학습되었다. 즉, 종래의 변환 이미지를 생성하는 인공지능 모델은 이미지가 존재하는 이미지 공간 상에서 이미지를 입력 받아 변환 이미지를 출력하도록 학습되었다.
그러나, 이미지 공간 상의 이미지는 이미지 변환에 불필요한 정보를 포함하고 그 크기가 클 수 있다는 점에서, 인공지능 모델이 입력된 이미지의 속성을 변환하고, 실제 이미지에 가까운 변환 이미지를 생성하는 과정에서 많은 자원이 필요로 될 수 있다. 즉, 종래의 인공지능 모델을 이용하여 이미지 변환을 수행할 경우 인공지능 모델을 포함하는 전자 장치의 부하가 증가하거나 이미지 변환의 명확성이 낮아지는 문제가 존재하였다.
본 개시는 상술한 문제점을 해결하기 위한 것으로, 구체적으로 인공지능 모델의 학습으로 생성된 잠재 공간 상에서 이미지 변환이 이뤄지도록 하여, 이미지의 추론 정확도를 높이고, 명확한 이미지를 생성하도록 하는 전자 장치 및 이의 제어 방법을 제공함에 있다.
본 개시의 일 실시 예에 따른 전자 장치는 기생성된 잠재 공간에 관한 정보가 저장된 메모리, 및 이미지를 상기 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 상기 잠재 공간 상의 이미지 데이터로 변환하고, 상기 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하며, 상기 이미지 데이터 및 상기 속성 변환 데이터를 기초로, 상기 이미지 데이터에 대한 변환 이미지 데이터를 생성하고, 상기 변환 이미지 데이터를 기초로 상기 입력 이미지에 대한 변환 이미지를 생성하는 프로세서를 포함한다. 이때, 상기 속성 변환 데이터 및 상기 변환 이미지 데이터는 상기 잠재 공간 상의 데이터이다.
한편, 본 개시의 일 실시 예에 따른 전자 장치의 제어 방법은, 이미지를 기생성된 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 상기 잠재 공간 상의 이미지 데이터로 변환하는 단계, 상기 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하는 단계, 상기 이미지 데이터 및 상기 속성 변환 데이터를 기초로, 상기 이미지 데이터에 대한 변환 이미지 데이터를 생성하는 단계, 및 상기 변환 이미지 데이터를 기초로 상기 입력 이미지에 대한 변환 이미지를 생성하는 단계를 포함한다. 이때, 상기 속성 변환 데이터 및 상기 변환 이미지 데이터는 상기 잠재 공간 상의 데이터이다.
도 1은 본 개시의 다양한 실시 예에 따른 전자 장치를 개략적으로 설명하기 위한 도면,
도 2는 본 개시의 다양한 실시 예에 따른 전자 장치의 구성을 설명하기 위한 블록도,
도 3은 본 개시의 일 실시 예에 따라 타겟 속성 값을 기초로 이미지 변환을 수행하는 전자 장치를 설명하기 위한 도면,
도 4는 본 개시의 일 실시 예에 따라 전자 장치에 포함된 변환 네트워크의 학습 과정을 설명하기 위한 도면,
도 5는 본 개시의 일 실시 예에 따른 전자 장치가 생성한 변환 이미지를 설명하기 위한 도면,
도 6은 본 개시의 일 실시 예에 따른 전자 장치의 세부 구성을 설명하기 위한 블록도, 및
도 7은 본 개시의 다양한 실시 예에 따른 전자 장치의 제어 방법을 설명하기 위한 흐름도이다.
본 개시에 대하여 구체적으로 설명하기에 앞서, 본 명세서 및 도면의 기재 방법에 대하여 설명한다.
본 개시에서 사용되는 용어는 본 개시의 다양한 실시 예들에서의 기능을 고려하여 일반적인 용어들을 선택하였다. 하지만, 이러한 용어들은 당해 기술 분야에 종사하는 기술자의 의도나 법률적 또는 기술적 해석 및 새로운 기술의 출현 등에 따라 달라질 수 있다. 또한, 일부 용어는 출원인이 임의로 선정한 용어도 있다. 이러한 용어에 대해서는 본 명세서에서 정의된 의미로 해석될 수 있으며, 구체적인 용어 정의가 없으면 본 명세서의 전반적인 내용 및 당해 기술 분야의 통상적인 기술 상식을 토대로 해석될 수도 있다.
이하, 본 개시의 다양한 실시 예가 첨부된 도면을 참조하여 기재된다. 그러나, 이는 본 개시에 기재된 기술을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 개시의 실시 예의 다양한 변경(modifications), 균등물(equivalents), 및/또는 대체물(alternatives)을 포함하는 것으로 이해되어야 한다.
또한, 본 개시에 첨부된 각 도면에 기재된 동일한 참조번호 또는 부호는 실질적으로 동일한 기능을 수행하는 부품 또는 구성요소를 나타낸다. 설명 및 이해의 편의를 위해서 서로 다른 실시 예들에서도 동일한 참조번호 또는 부호를 사용하여 설명한다. 즉, 복수의 도면에서 동일한 참조 번호를 가지는 구성요소를 모두 도시되어 있다고 하더라도, 복수의 도면들이 하나의 실시 예를 의미하는 것은 아니다.
본 개시에서 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 출원에서, "포함하다" 또는 "구성되다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
본 개시에서, "가진다," "가질 수 있다," "포함한다," 또는 "포함할 수 있다" 등의 표현은 해당 특징(예: 수치, 기능, 동작, 또는 부품 등의 구성요소)의 존재를 가리키며, 추가적인 특징의 존재를 배제하지 않는다.
본 개시에서, "A 또는 B," "A 또는/및 B 중 적어도 하나," 또는 "A 또는/및 B 중 하나 또는 그 이상"등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. 예를 들면, "A 또는 B," "A 및 B 중 적어도 하나," 또는 "A 또는 B 중 적어도 하나"는, (1) 적어도 하나의 A를 포함, (2) 적어도 하나의 B를 포함, 또는 (3) 적어도 하나의 A 및 적어도 하나의 B 모두를 포함하는 경우를 모두 지칭할 수 있다.
본 개시에서 사용된 "제1," "제2," "첫째," 또는 "둘째,"등의 표현들은 다양한 구성요소들을, 순서 및/또는 중요도에 상관없이 수식할 수 있고, 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 뿐 해당 구성요소들을 한정하지 않는다. 일 예로, 이러한 서수와 결합된 구성요소는 그 숫자에 의해 사용 순서나 배치 순서 등이 제한되어서는 안 된다. 필요에 따라서는, 각 서수들은 서로 교체되어 사용될 수도 있다.
어떤 구성요소(예: 제1 구성요소)가 다른 구성요소(예: 제2 구성요소)에 "(기능적으로 또는 통신적으로) 연결되어((operatively or communicatively) coupled with/to)" 있다거나 "접속되어(connected to)" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제3 구성요소)를 통하여 연결될 수 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소(예: 제1 구성요소)가 다른 구성요소(예: 제2 구성요소)에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소와 상기 다른 구성요소 사이에 다른 구성요소(예: 제 3 구성요소)가 존재하지 않는 것으로 이해될 수 있다.
본 개시에서 사용된 표현 "~하도록 구성된(또는 설정된)(configured to)"은 상황에 따라, 예를 들면, "~에 적합한(suitable for)," "~하는 능력을 가지는(having the capacity to)," "~하도록 설계된(designed to)," "~하도록 변경된(adapted to)," "~하도록 만들어진(made to)," 또는 "~를 할 수 있는(capable of)"과 바꾸어 사용될 수 있다. 용어 "~하도록 구성된(또는 설정된)"은 하드웨어적으로 "특별히 설계된(specifically designed to)" 것만을 반드시 의미하지 않을 수 있다. 대신, 어떤 상황에서는, "~하도록 구성된 장치"라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 "~할 수 있는" 것을 의미할 수 있다. 예를 들면, 문구 "A, B, 및 C를 수행하도록 구성된(또는 설정된) 부프로세서"는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(generic-purpose processor)(예: CPU(Central Processing Unit) 또는 application processor)를 의미할 수 있다.
한편, 본 개시에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
이하에서는 도면을 참조하여 본 개시에 대해 상세히 설명하기로 한다.
도 1은 본 개시의 다양한 실시 예에 따른 전자 장치를 개략적으로 설명하기 위한 도면이다.
본 개시에 따른 전자 장치(100)는 스마트폰, 태블릿 PC, 이동 전화기, 영상 전화기, 전자책 리더기, 데스크탑 PC, 랩탑 PC, 넷북 컴퓨터, 워크스테이션, 서버, PDA, PMP(portable multimedia player), MP3 플레이어, 키오스크, 의료기기, 카메라, 또는 웨어러블 장치 중 적어도 하나를 포함할 수 있다. 웨어러블 장치는 액세서리형(예: 시계, 반지, 팔찌, 발찌, 목걸이, 안경, 콘택트 렌즈, 또는 머리 착용형 장치(head-mounted-device(HMD)), 직물 또는 의류 일체형(예: 전자 의복), 신체 부착형(예: 스킨 패드), 또는 생체 이식형 회로 중 적어도 하나를 포함할 수 있다. 어떤 실시예들에서, 전자 장치는, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스, 홈 오토매이션 컨트롤 패널, 보안 컨트롤 패널, 미디어 박스, 게임 콘솔, 전자 사전, 전자 키, 캠코더, 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
전자 장치(100)는 이미지(11)에 대한 변환 이미지(12)를 생성할 수 있다. 이때, 이미지(11)는 전자 장치(100)에 저장되어 있는 이미지, 전자 장치(100)에 포함된 카메라(미도시)를 이용하여 획득된 이미지, 전자 장치(100)가 외부 장치(미도시)로부터 수신한 이미지 또는 전자 장치(100)가 생성한 가상 이미지와 같이 다양한 이미지가 될 수 있다.
이미지(11)는 특정 오브젝트를 촬상한 이미지로, 적어도 하나의 오브젝트를 포함할 수 있다. 또한, 이미지(11)는 JPEG (Joint Photographic Experts Group), GIF(Graphics Interchange Format), PNG(Potable Network Graphics), TIFF(Tag Image File Fomat), BMP(Microsoft Windows Device Independent Bitmap), HEIF(High Efficiency Image File Format), BPG(Better Portable Graphics), Raw와 같은 래스터 방식의 이미지이거나 AI(Adobe Illustrator), SVG(Scalable Vector Graphics), VML(Vector Markup Language), CGM(Computer Graphics Metafile), 거버 포맷(Gerber format)과 같은 벡터 방식의 이미지이거나 PDF(Portable Document Format), EPS(Encapsulated Postscript)와 같은 복합 방식의 이미지일 수 있다.
이미지(11)는 복수의 속성 정보를 포함할 수 있다. 본 개시에서 이미지의 속성은 이미지에 포함된 배경 또는 객체의 색상, 크기, 형태, 모양과 같이 이미지에 포함된 배경 또는 객체를 나타내는 다양한 요소일 수 있다. 가령, 이미지에 사람 이미지(객체)가 포함된 경우, 사람의 성별, 나이, 키, 머리 스타일, 머리 길이, 머리 색깔, 눈/코/입의 크기 또는 모양, 피부 색 또는 인종과 같은 다양한 요소들이 속성 정보가 될 수 있다.
전자 장치(100)는 이미지(11)에 포함된 복수의 속성 정보 중 적어도 하나의 속성 정보를 변환하여 변환 이미지(12)를 생성할 수 있다.
변환 이미지(12)를 생성하기 위하여, 전자 장치(100)는 이미지(11)를 잠재 공간(Latent space)(20) 상의 이미지 데이터(21)로 변환할 수 있다. 본 개시에서, 잠재 공간은 실제 관찰 공간(observation space) 또는 실제 이미지가 존재하는 이미지 공간(image space)에 대응되는 공간으로, 실제 관찰 공간 또는 이미지 공간 내에 존재하는 이미지가 설명될 수 있는 공간을 나타낸다.
구체적으로, 전자 장치(100)는 실제 관찰 공간 또는 이미지 공간의 다차원의 이미지 데이터 셋의 차원을 축소하여 새로운 차원의 이미지 데이터 셋을 생성함으로써, 잠재 공간을 미리 생성할 수 있다. 이때, 차원은 이미지의 속성 정보에 대응되는 개념일 수 있다. 즉, 전자 장치(100)는 이미지 데이터 셋에 포함된 복수의 속성 정보 중 이미지를 표현하는데 필요한 속성 정보만을 포함하도록 이미지 데이터 셋의 차원을 축소하여 잠재 공간을 미리 생성할 수 있다.
전자 장치(100)는 이미지(11)를 잠재 공간 상의 데이터로 정규화하는 함수 F를 이용하여 이미지(11)를 잠재 공간 상의 이미지 데이터(21)로 변환할 수 있다. 본 개시에서 정규화는 이미지(11)에 포함된 데이터의 범위를 사용자가 원하는 범위 또는 기설정된 범위로 제한하는 것을 의미한다. 함수 F는 이미지(11)를 정규화하여 잠재 공간 상의 이미지 데이터(21)로 변환하는 함수를 의미한다. 가령, 함수 F의 입력으로 이미지(11)가 입력되면, 함수 F는 이미지(11)에 포함된 데이터의 범위를 사용자가 원하는 범위 또는 기설정된 범위로 제한하여 잠재 공간 상의 이미지 데이터(21)로 변환할 수 있다.
이때, 잠재 공간 상의 이미지 데이터는 벡터의 형태로 표현될 수 있다. 또한, 이미지 데이터(21)는 이미지에 포함된 속성 정보의 전부 또는 일부를 포함할 수 있다.
한편, 전자 장치(100)는 인공지능 모델을 포함할 수 있다. 본 개시에서 인공지능 모델은 머신 러닝(또는 기계 학습) 또는 딥 러닝을 통하여 학습된 인공 신경망을 포함하는 인공지능 모델일 수 있다. 인공지능 모델은, 복수의 신경망 레이어들로 구성될 수 있다. 복수의 신경망 레이어들 각각은 복수의 가중치들(weight values)을 갖고 있으며, 이전(previous) 레이어의 연산 결과와 복수의 가중치들 간의 연산을 통해 신경망 연산을 수행한다. 복수의 신경망 레이어들이 갖고 있는 복수의 가중치들은 인공지능 모델의 학습 결과에 의해 최적화될 수 있다. 예를 들어, 학습 과정 동안 인공지능 모델에서 획득한 로스(loss) 값 또는 코스트(cost) 값이 감소 또는 최소화되도록 복수의 가중치들이 갱신될 수 있다. 인공 신경망은 심층 신경망(DNN:Deep Neural Network)를 포함할 수 있으며, 예를 들어, CNN (Convolutional Neural Network), DNN (Deep Neural Network), RNN (Recurrent Neural Network), RBM (Restricted Boltzmann Machine), DBN (Deep Belief Network), BRDNN(Bidirectional Recurrent Deep Neural Network) 또는 심층 Q-네트워크 (Deep Q-Networks) 등이 있으나, 전술한 예에 한정되지 않는다.
전자 장치(100)는 전자 장치(100)에 포함된 인공지능 모델의 학습 과정에서 잠재 공간(20)을 생성할 수 있다.
구체적으로, 전자 장치(100)는 이미지를 잠재 공간 상의 데이터로 정규화하도록 학습된 인공지능 모델을 포함할 수 있다. 이때, 인공지능 모델은 이미지를 잠재 공간 상의 데이터로 정규화하는 함수 F를 포함할 수 있다.
전자 장치(100)는 복수의 학습 이미지를 잠재 공간 상의 데이터로 정규화하도록 학습하는 과정에서 잠재 공간(20)을 생성할 수 있다.
이와 같이, 전자 장치(100)는 미리 생성된 잠재 공간(20) 상에서 이미지 데이터(21)를 생성하고 생성된 이미지 데이터(21)를 변환하여 변환 이미지 데이터(22)를 생성할 수 있다.
그리고, 전자 장치(100)는 변환 이미지 데이터(22)를 이용하여 변환 이미지(12)를 생성할 수 있다. 구체적으로, 전자 장치(100)는 함수 F의 역함수 F-1을 이용하여 변환 이미지 데이터(22)를 변환 이미지(12)로 변환할 수 있다.
이와 같이, 본 개시에 따른 전자 장치(100)는 이미지 데이터 셋의 차원이 축소된 잠재 공간 상에서 이미지 변환을 수행할 수 있다. 이 경우, 전자 장치(100)는 잠재 공간 상의 이미지 데이터에 대한 직접적인 추론을 할 수 있다. 또한, 전자 장치(100)는 이미지 데이터 셋의 차원이 축소된 잠재 공간 상에서 변환된 이미지 데이터에 대한 추론을 수행한다는 점에서, 전자 장치(100)의 리소스 사용 및 부하가 줄어들 수 있으며, 사용자의 의도에 보다 부합하게 변환된 변환 이미지를 제공할 수 있다.
도 2는 본 개시의 다양한 실시 예에 따른 전자 장치의 구성을 설명하기 위한 블록도이다.
도 2에 도시된 바와 같이, 전자 장치(100)는 메모리(110) 및 프로세서(120)를 포함할 수 있다. 본 개시에 따른 인공지능과 관련된 기능은 프로세서와 메모리를 통해 동작된다.
메모리(110)는 전자 장치(100)의 구성요소들의 전반적인 동작을 제어하기 위한 운영체제(OS: Operating System) 및 전자 장치(100)의 구성요소와 관련된 적어도 하나의 인스트럭션 또는 데이터를 저장하기 위한 구성이다. 인스트럭션은 프로그래밍 작성 언어에서 프로세서(120)가 직접 실행할 수 있는 하나의 동작 문장(action statement)을 의미하며, 프로그램의 실행 또는 동작에 대한 최소 단위이다.
프로세서(120)는 메모리(110)에 저장된 적어도 하나의 인스트럭션을 실행함으로써 후술할 다양한 실시 예들에 따른 동작을 수행할 수 있다.
메모리(110)는 전자 장치(100)의 동작에 필요한 각종 프로그램 및 데이터 등을 저장하기 위한 구성요소이다. 메모리(110)는 비휘발성 메모리, 휘발성 메모리, 플래시메모리(flash-memory), 하드디스크 드라이브(HDD) 또는 솔리드 스테이트 드라이브(SSD) 등으로 구현될 수 있다. 메모리(110)는 프로세서(120)에 의해 액세스되며, 프로세서(120)에 의한 데이터의 독취/기록/수정/삭제/갱신 등이 수행될 수 있다. 본 개시에서 메모리라는 용어는 메모리(110), 프로세서(120) 내 롬(미도시), 램(미도시) 또는 전자 장치(100)에 장착되는 메모리 카드(미도시)(예를 들어, micro SD 카드, 메모리 스틱)를 포함할 수 있다.
메모리(110)에는 기생성된 잠재 공간(20)에 관한 정보가 저장되어 있을 수 있다. 도 1에서 상술한 바와 같이, 잠재 공간(20)은 다차원 이미지 데이터 셋의 차원을 축소하여 생성된 새로운 차원의 이미지 데이터 셋의 공간으로, 이미지 공간 내의 이미지가 설명될 수 있는 공간을 나타낸다.
그리고, 메모리(110)는 이미지(11)를 변환 이미지(12)로 변환하는데 사용되는 인공지능 모델을 저장할 수 있다.
구체적으로, 메모리(110)는 이미지(11)를 잠재 공간 상의 데이터로 정규화하도록 학습된 플로우 기반 생성 모델(flow-based generative model) 및 잠재 공간 상의 이미지 데이터(21)를 변환하여 변환 이미지 데이터(22)를 생성하는 변환 네트워크 모델(translator network model)을 포함할 수 있다.
플로우 기반 생성 모델은 학습 이미지의 특징을 학습하여 학습 이미지와 유사한 이미지 데이터를 생성하도록 학습된 인공지능 모델일 수 있다. 이때, 학습 이미지와 유사한 이미지 데이터는 벡터 형태로 표현될 수 있다.
플로우 기반 생성 모델은 복수의 이미지를 복수의 이미지 데이터로 변환하도록 학습하면서 잠재 공간을 생성할 수 있다. 즉, 잠재 공간(20)은 플로우 기반 생성 모델의 학습 시에 생성되는 학습 이미지 데이터 셋의 집합을 나타낼 수 있다.
플로우 기반 생성 모델은 역변환이 가능한 네트워크이다. 여기에서, 역변환이 가능하다는 것은 네트워크의 출력 값을 입력으로 하여 입력 값을 출력할 수 있음을 나타낸다. 즉, 플로우 기반 생성 모델은 이미지를 입력으로 하여 이미지 데이터를 출력하도록 학습되었을 뿐만 아니라, 역으로 이미지 데이터를 입력으로 하여 이미지를 생성하도록 학습된 인공지능 모델일 수 있다.
플로우 기반 생성 모델은 적어도 하나 이상의 역변환이 가능한 네트워크를 포함할 수 있다. 가령, 플로우 기반 생성 모델은, squeeze 네트워크, actnorm 네트워크, 1x1 convolution 네트워크, coupling 네트워크 및 split 네트워크와 같은 복수의 네트워크를 포함할 수 있으며, squeeze 네트워크, actnorm 네트워크, 1x1 convolution 네트워크, coupling 네트워크 및 split 네트워크는 각각 역변환이 가능한 네트워크 일 수 있다. 한편, 플로우 기반 생성 모델에 포함되는 네트워크의 종류 및 형태는 경우에 따라 상이할 수 있다는 점 및 squeeze 네트워크, actnorm 네트워크, 1x1 convolution 네트워크, coupling 네트워크 및 split 네트워크는 공지된 기술인 점을 고려하여, 구체적인 설명을 생략하도록 한다.
변환 네트워크 모델은 잠재 공간 상의 이미지 데이터를 기초로 이미지의 속성을 변환하기 위한 속성 변환 데이터를 출력하도록 학습된 인공지능 모델일 수 있다. 구체적으로, 변환 네트워크 모델은 잠재 공간 상의 이미지 데이터, 이미지의 원래 속성 값 및 이미지의 타겟 속성 값을 기초로, 이미지의 속성을 원래 속성 값에서 타겟 속성 값으로 변환하기 위한 속성 변환 데이터를 제공하도록 학습된 모델일 수 있다. 이때, 속성 변환 데이터는 잠재 공간 상의 데이터로 벡터로 표현될 수 있다. 변환 네트워크 모델의 구체적인 동작에 대해서는 도 3에서 후술하기로 한다.
한편, 메모리(110)는 변환 네트워크 모델을 학습하는데 필요한 prior 네트워크 모델 및 속성 분류 네트워크 모델을 포함할 수 있다. 구체적으로, prior 네트워크 모델 및 속성 분류 네트워크 모델은 변환 네트워크의 모델의 학습 과정에서 사용되어 변환 네트워크의 정확도를 높일 수 있다.
구체적으로, prior 네트워크는 이미지의 원래 속성 값 및 이미지의 타겟 속성 값을 기초로, 이미지의 속성을 원래 속성 값에서 타겟 속성 값으로 변환하기 위한 속성 변환 데이터의 분포를 출력하도록 학습된 모델일 수 있다. prior 네트워크를 통하여 출력된 속성 변환 데이터의 정규 분포를 기초로, 변환 네트워크는 속성 변환 데이터의 분포를 정확하게 출력할 수 있다.
속성 분류 네트워크 모델은 이미지 데이터에 포함된 이미지 속성 값을 출력하도록 학습된 모델일 수 있다. 속성 분류 네트워크 모델은 변환 네트워크가 출력한 속성 변환 데이터를 기초로 생성된 변환 이미지 데이터의 속성 값을 출력할 수 있다. 속성 분류 네트워크 모델은 변환 네트워크를 통하여 생성된 변환 이미지 데이터의 속성 값이 타겟 속성 값을 포함하는지 판단할 수 있다. 속성 분류 네트워크를 통하여 출력된 변환 이미지 데이터의 속성 값을 이용하여, 변환 네트워크는 타겟 속성 값을 포함하는 변환 이미지 데이터를 정확하게 출력할 수 있다.
변환 네트워크를 학습시키는 과정에서 사용되는 prior 네트워크 모델 및 속성 분류 네트워크 모델에 관해서는 도 4에서 보다 구체적으로 후술하도록 한다.
프로세서(120)는 메모리(110)와 전기적으로 연결되어 전자 장치(100)의 전반적인 동작 및 기능을 제어할 수 있다. 예를 들어, 프로세서(120)는 운영 체제 또는 응용 프로그램을 구동하여 프로세서(120)에 연결된 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 각종 데이터 처리 및 연산을 수행할 수 있다. 또한, 프로세서(120)는 다른 구성요소들 중 적어도 하나로부터 수신된 명령 또는 데이터를 휘발성 메모리에 로드하여 처리하고, 다양한 데이터를 비휘발성 메모리에 저장할 수 있다.
이를 위해, 프로세서(120)는 해당 동작을 수행하기 위한 전용 프로세서(예, 임베디드 프로세서) 또는 메모리 디바이스에 저장된 하나 이상의 소프트웨어 프로그램을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(예: CPU (Central Processing Unit) 또는 AP(application processor))로 구현될 수 있다.
본 개시에서 프로세서는 하나 또는 복수의 프로세서로 구성될 수 있다. 이때, 하나 또는 복수의 프로세서는 CPU, AP, DSP(Digital Signal Processor) 등과 같은 범용 프로세서, GPU(Graphics Processing Unit), VPU(Vision Processing Unit)와 같은 그래픽 전용 프로세서 또는 NPU와 같은 인공지능 전용 프로세서일 수 있다. 하나 또는 복수의 프로세서는, 메모리에 저장된 기 정의된 동작 규칙 또는 인공지능 모델에 따라, 입력 데이터를 처리하도록 제어한다. 또는, 하나 또는 복수의 프로세서가 인공지능 전용 프로세서인 경우, 인공지능 전용 프로세서는, 특정 인공지능 모델의 처리에 특화된 하드웨어 구조로 설계될 수 있다.
기 정의된 동작 규칙 또는 인공지능 모델은 학습을 통해 만들어진 것을 특징으로 한다. 여기서, 학습을 통해 만들어진다는 것은, 기본 인공지능 모델이 학습 알고리즘에 의하여 다수의 학습 데이터들을 이용하여 학습됨으로써, 원하는 특성(또는, 목적)을 수행하도록 설정된 기 정의된 동작 규칙 또는 인공지능 모델이 만들어짐을 의미한다. 이러한 학습은 본 개시에 따른 인공지능이 수행되는 기기 자체에서 이루어질 수도 있고, 별도의 서버 및/또는 시스템을 통해 이루어 질 수도 있다. 학습 알고리즘의 예로는, 지도형 학습(supervised learning), 비지도형 학습(unsupervised learning), 준지도형 학습(semi-supervised learning) 또는 강화 학습(reinforcement learning)이 있으나, 전술한 예에 한정되지 않는다.
프로세서(120)는 잠재 공간(20)에 대한 정보를 기초로, 이미지(11)에 대한 변환 이미지(12)를 생성할 수 있다.
구체적으로, 프로세서(120)는 이미지(11)를 잠재 공간(20) 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 잠재 공간(20) 상의 이미지 데이터로 변환할 수 있다. 이때, 이미지(11)를 잠재 공간(20) 상의 데이터로 정규화하는 함수는 플로우 기반 생성 모델에 포함된 함수일 수 있다. 즉, 프로세서(120)는 플로우 기반 생성 모델을 이용하여 이미지(11)를 잠재 공간(20) 상의 이미지 데이터로 변환할 수 있다.
프로세서(120)는 이미지에 포함된 복수의 속성 중 적어도 하나의 속성에 대한 타겟 속성 값을 입력 받을 수 있다. 여기에서 타겟 속성 값은, 변경하고자 하는 이미지의 속성 값을 나타낸다. 가령, 이미지에 포함된 사람(객체)의 머리 색을 검은색에서 갈색으로 변경하려는 경우, '갈색'이 타겟 속성 값이 될 수 있다.
프로세서(120)는 이미지 데이터에 포함된 복수의 속성의 속성 값 중 타겟 속성 값에 대응되는 속성 값을 식별하고, 타겟 속성 값 및 속성 값의 차이를 이용하여 이미지 데이터의 변환을 판단할 수 있다. 구체적으로, 프로세서(120)는 타겟 속성 값 및 속성 값 간의 차이가 존재하는 경우 이미지 데이터의 변환이 필요하다고 판단할 수 있다. 반면, 입력된 타겟 속성 값과 현재 이미지의 속성 값과 차이가 없는 경우, 프로세서(120)는 이미지 데이터의 변환이 필요하지 않다고 판단할 수 있다.
도 3은 본 개시의 일 실시 예에 따라 타겟 속성 값을 기초로 이미지 변환을 수행하는 전자 장치를 설명하기 위한 도면이다.
도 1 및 도 2에서 상술한 바와 같이, 프로세서(120)는 이미지를 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 이미지(11)를 잠재 공간(20) 상의 이미지 데이터(21)로 변환할 수 있다.
이때, 이미지를 잠재 공간 상의 데이터로 정규화하는 함수가 플로우 기반 생성 모델(30)을 통하여 구현되는 경우, 프로세서(120)는 플로우 기반 생성 모델(30)을 이용하여 이미지(11)를 잠재 공간(20) 상의 이미지 데이터(21)로 변환할 수 있다. 프로세서(120)는 플로우 기반 생성 모델(30)에 이미지(11)를 입력하고, 입력된 이미지(11)에 대한 잠재 공간(20) 상의 이미지 데이터(21)를 획득할 수 있다.
프로세서(120)는 이미지 데이터(21)에 포함된 이미지의 속성 값(1)을 타겟 속성 값(2)으로 변경하기 위한 속성 변환 데이터(23)를 획득할 수 있다.
구체적으로, 프로세서(120)는 전자 장치(100)에 입력된 타겟 속성 값(2)과 타겟 속성 값에 대응되는 속성 값(1)을 식별하여 이미지 데이터(21)의 변환을 판단할 수 있다.
프로세서(120)는 이미지 데이터(21)의 변환이 필요하다고 판단된 경우, 타겟 속성 값(2) 및 속성 값(1)의 차이(3)를 기초로 속성 변환 데이터(23)를 추출할 수 있다.
프로세서(120)는 타겟 속성 값(2) 및 속성 값(1)의 차이(3)를 변환 네트워크(40)에 입력하여 속성 변환 데이터(23)를 출력할 수 있다.
도 2에서 상술한 바와 같이, 변환 네트워크(40)는 타겟 속성 값 및 속성 값의 차이를 입력으로 하여 속성 변환 데이터를 출력하도록 학습된 인공지능 모델이다. 변환 네트워크(40)는 변환 네트워크(40)의 학습 시 속성 변환 데이터의 분포를 학습할 수 있다. 여기에서 속성 변환 데이터는 잠재 공간(20)상의 데이터이며, 속성 변환 데이터의 분포는 정규 분포일 수 있다.
따라서, 변환 네트워크(40)는 타겟 속성 값(2) 및 속성 값(1)의 차이(3)가 입력되면, 속성 변환 데이터(23)의 분포(4)를 판단할 수 있다. 그리고, 변환 네트워크(40)는 속성 변환 데이터의 분포(4) 중 기설정된 조건을 만족하는 속성 변환 데이터(23)를 추출할 수 있다. 가령, 변환 네트워크(40)는 속성 변환 데이터의 분포(4)에서 평균 값에 대응되는 속성 변환 데이터(23)를 추출할 수 있다. 다만, 이는 일 실시 예일 뿐이며, 실시 예에 따라 변환 네트워크는 속성 변환 데이터의 분포(4)에서 조건을 만족하는 속성 변환 데이터(23)를 추출할 수 있다.
프로세서(120)는 이미지 데이터(21) 및 속성 변환 데이터(23)를 기초로, 이미지 데이터(21)에 대한 변환 이미지 데이터(22)를 생성할 수 있다. 이때, 생성되는 변환 이미지 데이터(22) 또한 잠재 공간(20) 상의 데이터이다.
구체적으로, 프로세서(120)는 플로우 기반 생성 모델(30)을 통하여 획득된 이미지 데이터(21)와 변환 네트워크(40)를 통하여 획득된 속성 변환 데이터(23)를 합하여, 변환 이미지 데이터(22)를 생성할 수 있다. 이미지 데이터(21) 및 속성 변환 데이터(23)는 잠재 공간(20) 상에서 벡터의 형태로 표시될 수 있다는 점에서, 프로세서(120)는 이미지 데이터(21) 및 속성 변환 데이터(23)를 합할 수 있으며, 그 결과 변환 이미지 데이터(22)를 생성할 수 있다.
프로세서(120)는 생성된 변환 이미지 데이터(22)를 기초로 입력 이미지(11)에 대한 변환 이미지(12)를 생성할 수 있다.
구체적으로, 프로세서(120)는 이미지를 잠재 공간 상의 데이터로 정규화하는 함수의 역함수를 생성하고, 변환 이미지 데이터(22)를 생성된 역함수의 입력으로 하여 이미지(11)에 대한 변환 이미지(12)를 생성할 수 있다.
이때, 이미지를 잠재 공간 상의 데이터로 정규화하는 함수가 플로우 기반 생성 모델(30)을 통하여 구현되는 경우, 프로세서(120)는 플로우 기반 생성 모델(30)을 이용하여 변환 이미지 데이터(22)를 변환 이미지(12)로 변환할 수 있다. 플로우 기반 생성 모델(30)은 역 변환이 가능하도록 학습된 인공지능 모델이라는 점에서, 프로세서(120)는 플로우 기반 생성 모델(30)에 변환 이미지 데이터(22)를 입력하여 변환 이미지(12)를 생성할 수 있다.
도 4는 본 개시의 일 실시 예에 따라 전자 장치에 포함된 변환 네트워크의 학습 과정을 설명하기 위한 도면이다.
상술한 바와 같이, 변환 네트워크(40)는 잠재 공간(20)상의 이미지 데이터, 속성 값 및 타겟 속성 값을 이용하여 속성 변환 데이터를 출력하도록 학습된 인공지능 모델이다.
프로세서(120)는 prior 네트워크(50) 및 속성 분류 네트워크(60)를 이용하여 변환 네트워크(40)를 학습 시킬 수 있다.
prior 네트워크(50)는 이미지의 속성 값 및 타겟 속성 값을 이용하여 이미지에서 속성 변환 데이터의 기준 분포를 출력하도록 학습된 인공지능 모델이다. 구체적으로, prior 네트워크(50)는 이미지의 속성을 속성 값에서 타겟 속성 값으로 변환하기 위해 잠재 공간(20)에서 어떤 속성 변환 데이터(23)가 필요한지를 속성 변환 데이터(23)의 분포를 통하여 제공할 수 있다.
프로세서(120)는 prior 네트워크(50)에 속성 값 및 타겟 속성 값의 차이 값을 입력하여 속성 변환 데이터의 기준 분포를 획득하고, 획득된 기준 분포를 이용하여 변환 네트워크(40)를 학습시킬 수 있다.
구체적으로, 프로세서(120)는 prior 네트워크(50)에 의해 출력되는 속성 변환 데이터의 분포를 변환 네트워크(40)의 분포(4)를 정규화하는데 사용될 수 있다. 이러한 점에서, prior 네트워크(50)는 속성 변환 데이터의 기준 분포를 출력하는 것으로 볼 수 있다.
변환 네트워크(40)는 속성 값 및 타겟 속성 값의 차이 외에도 이미지 데이터를 입력으로 받아 속성 변환 데이터를 출력하도록 학습하는데 반해, prior 네트워크(50)는 속성 값 및 타겟 속성 값의 차이만을 입력으로 받아 속성 변환 데이터의 분포를 출력하도록 학습될 수 있다. 즉, prior 네트워크(50)는 입력된 이미지에 관계 없이 속성 값 및 타겟 속성 값의 차이만 입력 받는다는 점에서, 다양한 이미지를 생성하기 위한 속성 변환 데이터의 분포 결과를 제공한다. 가령, 도 4에서 도시된 바와 같이, 타겟 속성 값이 '안경'이고, 원래 속성 값이 '안경을 쓰지 않음'인 경우, prior 네트워크(50)는 타겟 속성 값과 속성 값의 차이를 입력으로 받아 '안경이 추가된' 다양한 이미지를 생성하기 위한 속성 변환 데이터의 분포 결과를 제공할 수 있다.
프로세서(120)는 prior 네트워크(50)에 다양한 타겟 속성 값 및 속성 값을 입력하여 prior 네트워크(50)를 학습시킬 수 있으나, 메모리(110)에 이미 학습된 prior 네트워크(50)가 저장되어 있을 수도 있다. 이 경우, 프로세서(120)는 기 저장된 prior 네트워크(50)를 이용하여 변환 네트워크(40)를 학습시킬 수 있다.
구체적으로, 프로세서(120)는 학습 이미지 데이터, 학습 이미지 데이터의 속성 값 및 타겟 속성 값을 변환 네트워크(40)에 입력하여 변환 네트워크(40)가 속성 변환 데이터를 출력하도록 학습시키는 과정에서 속성 변환 데이터의 분포도 학습시킬 수 있는데, 이때, 프로세서(120)는 변환 네트워크(40)를 통한 분포가 prior 네트워크(50)를 통해 출력된 기준 분포와 동일하거나 유사한 형태를 가질 수 있도록 변환 네트워크(40)를 학습시킬 수 있다.
더욱 구체적으로, 프로세서(120)는 Kullback-Leiber divergence 를 이용하여, 변환 네트워크(40)를 통한 분포와 prior 네트워크(50)를 통해 출력된 기준 분포의 차이를 판단함으로써, 두 분포의 차이가 기 설정된 값 미만이 되도록 변환 네트워크(40)를 학습시킬 수 있다. 이와 같은 학습 결과, 변환 네트워크(40)는 정규화된 속성 변환 데이터를 출력할 수 있다.
한편, 도 2에서 상술한 바와 같이, 속성 분류 네트워크(60)는 잠재 공간(20) 상의 이미지 데이터를 입력으로 받아 이미지 속성 값을 출력하도록 학습된 인공지능 모델이다. 프로세서(120)는 잠재 공간(20) 상의 이미지 데이터(21)의 확률 및 이미지의 속성 값(1) 간의 교차 엔트로피(cross entropy)를 이용하여 속성 분류 네트워크(60)를 최적화시킬 수 있다.
프로세서(120)는 속성 분류 네트워크(60)를 이용하여, 변환 네트워크(40)가 정확한 속성 변환 데이터를 출력하도록 변환 네트워크(40)를 학습시킬 수 있다.
구체적으로, 프로세서(120)는, 변환 네트워크(40)를 학습시키는 과정에서, 학습 이미지의 이미지 데이터 및 변환 네트워크(40)에 의해 출력된 속성 변환 데이터를 기초로 학습 이미지의 이미지 데이터에 대한 변환 이미지 데이터를 획득한다. 이때, 프로세서(120)는 획득된 변환 이미지 데이터를 속성 분류 네트워크(60)에 입력하여 출력된 속성 값이 타겟 속성 값과 같아지도록 변환 네트워크(40)를 학습시킬 수 있다.
이와 같이, 프로세서(120)는 prior 네트워크(50) 및 속성 분류 네트워크(60)를 이용하여 변환 네트워크(40)를 학습시킴으로써, 변환 네트워크(40)가 타겟 속성 값에 부합하는 변환 이미지를 출력하도록 할 수 있다.
한편, 속성 분류 네트워크(60)는 변환 네트워크(40)를 학습시키는 과정뿐만 아니라, 변환 네트워크(40)의 추론 과정에서도 사용될 수 있다. 가령, 일 실시 예에 따라, 프로세서(120)는 변환 네트워크(40)에 의해 생성된 속성 변환 데이터를 기초로 생성된 변환 이미지 데이터가 타겟 속성 값을 포함하는지를 속성 분류 네트워크(60)를 이용하여 판단할 수 있다.
이때, 속성 분류 네트워크의 판단 결과, 변환 이미지 데이터(22)가 타겟 속성 값(2)을 포함하는 것으로 판단된 경우, 프로세서(120)는 변환 이미지 데이터(22)를 기초로 변환 이미지(12)를 생성할 수 있다.
도 5는 본 개시의 일 실시 예에 따른 전자 장치가 생성한 변환 이미지를 설명하기 위한 도면이다.
도 5a는 사람(객체)가 포함된 이미지(510)에서 안경, 앞머리, 금발과 같은 타겟 속성 값을 입력으로 받은 경우를 설명하기 위한 도면이고, 도 5b는 의류(객체)가 포함된 이미지에서 긴 팔, 와이드 넥(wide neck) 또는 슬림 핏(slim fit)과 같은 타겟 속성 값을 입력으로 받은 경우를 설명하기 위한 도면이다.
또한, 도 5a 및 도 5b는 본 개시에 따른 이미지 변환 방법의 효과를 설명하기 위하여, 본 개시의 이미지 변환 방법을 이용하여 변환된 변환 이미지 이외에 기존의 공지된 이미지 변환 방법으로 변환된 변환 이미지를 함께 개시하였다.
도 5a는 입력 이미지(510)를 기존의 이미지 변환 방법으로 변환한 경우((a) 및 (b)) 및 본 개시에 따른 이미지 변환 방법으로 변환한 경우(c)를 도시하고 있다.
기존의 이미지 변환 방법의 경우, 각 특정 속성에 대한 이미지의 평균 잠재 벡터를 계산하고 저장한다. 그 후, 평균 잠재 벡터의 차이를 사용하여 원래 잠재 벡터를 원하는 벡터로 변환한다. 이때, 다양한 변환 결과를 생성할 수 있도록 노이즈가 평균 잠재 벡터의 차이에 추가될 수 있다.
도 5a의 (a)의 경우, 즉, 테이블(510, 520 및 530)의 첫번째 행의 이미지들은 평균 잠재 벡터의 차이에 노이즈가 추가되지 않은 경우의 변환 이미지를 나타내는 것이며, 도 5a의 (b)의 경우, 즉, 테이블(510, 520 및 530)의 두번째 행의 이미지들은 잠재 벡터의 차이에 노이즈가 추가된 경우의 변환 이미지를 나타내는 것이다.
한편, 도 5a (c)의 경우, 즉, 테이블(510, 520 및 530)의 세번째 행의 이미지들은 본 개시의 이미지 변환 방법에 따라 생성된 변환 이미지를 나타내는 것이다.
도 5a의 타겟 속성 값이 '안경'인 경우의 테이블(520), 타겟 속성 값이 '앞머리'인 경우의 테이블(530) 및 타겟 속성 값이 '금발'인 경우의 테이블(530)을 참조하면, 종래의 이미지 변환 방법의 경우보다 본 개시에 따른 이미지 변환 방법에 따를 경우, 타겟 속성 값에 부합하는 변환 이미지가 생성되는 것을 알 수 있다.
마찬가지로, 도 5b의 경우, 각 테이블(550, 560, 및 570)의 첫번째 행은 의류(객체)를 포함하는 입력 이미지를 나타내고, 두번째 행은 종래의 이미지 변환 방법에 따라 변환된 이미지를 나타내며, 세번째 행은 본 개시에 따른 이미지 변환 방법에 따라 변환된 이미지를 나타낸다.
도 5b의 타겟 속성 값이 '긴 팔'인 경우의 테이블(550), 타겟 속성 값이 '와이드 넥'인 경우의 테이블(560) 및 타겟 속성 값이 '슬림 핏'인 경우의 테이블(570)을 각각 참조하면, 종래의 이미지 변환 방법의 경우보다 본 개시에 따른 이미지 변환 방법에 따를 경우, 타겟 속성 값에 부합하는 변환 이미지가 생성되는 것을 알 수 있다.
이와 같이, 본 개시에 따른 이미지 변환 방법을 사용할 경우, 프로세서(120)가 타겟 속성 값을 보다 정확하게 반영하여 변환된 변환 이미지를 획득할 수 있다.
도 6은 본 개시의 일 실시 예에 따른 전자 장치의 세부 구성을 설명하기 위한 블록도이다.
도 6에 도시된 바와 같이, 본 개시에 따른 전자 장치(100)는 메모리(110), 프로세서(120) 외에도 카메라(130), 디스플레이(140), 통신 인터페이스(150) 및 입력 인터페이스(160)를 포함할 수 있다. 이와 관련하여, 도 2의 메모리(110) 및 프로세서(120)와 중복되는 설명에 관하여는 생략하기로 한다.
카메라(130)는 이미지를 촬상하기 위한 구성 요소이다. 카메라(130)는 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 하나 이상의 이미지 센서(예를 들어, 전면 센서 또는 후면 센서), 렌즈, 이미지 시그널 프로세서(ISP), 플래시(예를 들어, LED, Xenon lamp 등)를 포함할 수 있다.
디스플레이(140)는 이미지를 표시하기 위한 구성 요소이다. 디스플레이(140)는 이미지(11) 및 변환 이미지(12)를 표시할 수 있다. 또한, 디스플레이(140)는 이미지(11)가 변환 이미지(12)로 변환되는 과정을 표시할 수도 있다. 그리고, 디스플레이(140)는 타겟 속성 값을 입력 받기 위한 어플리케이션 화면, GUI(Graphic User Interface)화면 등을 포함할 수 있다.
디스플레이(140)는 LCD(Liquid Crystal Display), OLED(Organic Light Emitting Diodes) 디스플레이, PDP(Plasma Display Panel), Wall, Micro LED 등과 같은 다양한 형태의 디스플레이로 구현될 수 있다. 또한, 디스플레이(140)는 터치 센서와 결합된 터치 스크린, 플렉시블 디스플레이(flexible display), 3차원 디스플레이(3D display) 등으로 구현될 수 있다.
통신 인터페이스(150)는 전자 장치(100)가 외부 전자 장치(미도시)와 통신을 수행하기 위한 구성 요소이다. 전자 장치(100)는 통신 인터페이스(150)를 통하여 외부 전자 장치(미도시)로부터 이미지를 수신할 수 있으며, 수신된 이미지를 변환하여 변환 이미지를 외부 전자 장치(미도시)에 전송할 수 있다.
통신 인터페이스(150)는 유선 통신 모듈(미도시), 근거리 무선 통신 모듈(미도시), 무선 통신 모듈(미도시) 등과 같은 다양한 통신 모듈을 포함할 수 있다.
여기에서, 유선 통신 모듈은 유선 이더넷(Ethernet)과 같이 유선 통신 방식에 따라 외부 장치(미도시)와 통신을 수행하기 위한 모듈이다. 그리고, 근거리 무선 통신 모듈이란 블루투스(Bluetooth, BT), BLE(Bluetooth Low Energy), ZigBee 방식 등과 같은 근거리 무선 통신 방식에 따라 근거리에 위치한 외부 장치(미도시)와 통신을 수행하기 위한 모듈이다. 또한, 무선 통신 모듈이란 WiFi, IEEE 등과 같은 무선 통신 프로토콜에 따라 외부 네트워크에 연결되어 외부 장치(미도시) 및 음성 인식 서버(미도시)와 통신을 수행하는 모듈이다. 이 밖에 무선 통신 모듈은 3G(3rd Generation), 3GPP(3rd Generation Partnership Project), LTE(Long Term Evolution), LTE-A(LTE Advanced), 5세대 네트워크(5G Networks) 등과 같은 다양한 이동 통신 규격에 따라 이동 통신망에 접속하여 통신을 수행하는 이동 통신 모듈을 더 포함할 수도 있다.
입력 인터페이스(160)는 전자 장치(100)를 제어하기 위한 사용자 입력을 수신하기 위한 구성 요소이다. 특히, 입력 인터페이스(160)는 타겟 속성 값에 대한 사용자의 입력을 수신할 수 있다. 입력 인터페이스(160)는 사용자의 손 또는 스타일러스 펜 등을 이용한 사용자 터치를 입력 받기 위한 터치 패널(161), 사용자의 조작을 입력 받이 위한 키보드(162) 및 사용자의 음성 명령을 입력 받기 위한 마이크(163)를 포함할 수 있다. 다만 반드시 이에 한하는 것은 아니며, 실시 예에 따라 버튼(미도시)과 같은 다양한 입력 수단이 추가될 수 있다.
도 7은 본 개시의 다양한 실시 예에 따른 전자 장치의 제어 방법을 설명하기 위한 흐름도이다.
우선, 이미지를 기생성된 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 잠재 공간 상의 이미지 데이터로 변환할 수 있다(S710). 여기에서, 잠재 공간은 실제 관찰 공간 또는 이미지 공간의 다차원의 이미지 데이터 셋의 차원을 축소하여 생성된 공간을 나타낸다. 또한, 잠재 공간은 입력 이미지를 이미지 데이터로 변환하도록 학습된 함수를 포함하는 플로우 기반 생성 모델이 이미지를 이미지 데이터로 변환하도록 학습하면서 생성하는 공간일 수 있다.
그리고, 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득할 수 있다(S720). 이때, 속성 변환 데이터는 잠재 공간 상의 데이터일 수 있다.
속성 변환 데이터를 획득하기 위하여, 전자 장치는 타겟 속성 값을 입력 받아, 이미지 데이터에 포함된 복수의 속성 값 중 타겟 속성 값에 대응되는 속성 값을 식별할 수 있다. 그리고, 식별된 타겟 속성 값 및 속성 값 간의 차이를 이용하여 이미지 데이터의 변환을 판단할 수 있다. 가령, 식별된 타겟 속성 값과 속성 값 간의 차이가 존재하는 경우, 이미지 변환이 필요하다고 판단하여, 타겟 속성 값과 속성 값 간의 차이를 기초로 속성 변환 데이터를 추출할 수 있다.
이때, 속성 변환 데이터를 추출하도록 학습된 변환 네트워크를 이용하여 속성 변환 데이터를 추출할 수 있다. 구체적으로, 속성 값 및 타겟 속성 값의 차이 값을 변환 네트워크에 입력하여 속성 변환 네트워크를 추출할 수 있다.
여기에서, 변환 네트워크는 변환 네트워크의 학습 단계에서, 이미지 데이터의 속성 값을 타겟 속성 값으로 변환하기 위한 속성 변환 데이터의 분포를 학습할 수 있다. 그리고, 변환 네트워크에 속성 값 및 타겟 속성 값의 차이 값이 입력되면, 속성 변환 데이터의 분포를 판단하고 판단된 속성 변환 데이터의 분포에서 기설정된 조건을 만족하는 속성 변환 데이터를 추출할 수 있다.
이미지 데이터 및 속성 변환 데이터를 기초로, 이미지 데이터에 대한 변환 이미지 데이터를 생성할 수 있다(S730). 구체적으로, 이미지 데이터 및 속성 변환 데이터의 합을 이용하여 변환 이미지 데이터를 생성할 수 있다. 이미지 데이터 및 속성 변환 데이터가 잠재 공간 상의 데이터라는 점에서, 변환 이미지 데이터 또한 잠재 공간 상의 데이터일 수 있다.
그리고, 변환 이미지 데이터를 기초로 입력 이미지에 대한 변환 이미지를 생성할 수 있다(S740).
구체적으로, 이미지를 기생성된 잠재 공간 상의 데이터로 정규화하는 함수의 역함수를 생성하고, 잠재 공간 상의 변환 이미지 데이터를 역함수의 입력으로 하여 입력 이미지에 대한 변환 이미지를 생성할 수 있다.
또는, 이미지를 정규화하는 함수가 플로우 기반 생성 모델을 통하여 구현되는 경우, 플로우 기반 생성 모델에 변환 이미지 데이터를 입력하여 변환 이미지를 획득할 수 있다. 이때, 플로우 기반 생성 모델은 역변환이 가능한 인공지능 모델이라는 점에서, 이미지로부터 이미지 데이터를 생성하는 것뿐 만 아니라, 역으로 이미지 데이터에서 이미지를 생성할 수도 있다.
한편, 변환 네트워크는 prior 네트워크 및 속성 분류 네트워크에 의해 학습될 수 있다.
구체적으로, prior 네트워크는 이미지의 속성 값 및 타겟 속성 값을 이용하여 속성 변환 데이터의 기준 분포를 출력하도록 학습된 인공지능 모델이다. prior 네트워크에 속성 값 및 타겟 속성 값의 차이 값을 입력하여 속성 변환 데이터의 기준 분포를 획득하고, 획득된 기준 분포를 이용하여 변환 네트워크를 학습시킬 수 있다.
속성 분류 네트워크는 이미지 데이터를 입력 받아 이미지 데이터에 포함된 이미지의 속성 값을 출력하도록 학습된 인공지능 모델이다. 속성 분류 네트워크에 변환 네트워크에 의해 생성된 변환 이미지 데이터를 입력하여 출력된 속성 값이 타겟 속성 값과 일치하도록 변환 네트워크를 학습시킬 수 있다.
한편, 일 실시 예에 따라, 속성 분류 네트워크는 변환 네트워크에 의해 생성된 변환 이미지 데이터가 타겟 속성 값을 포함하는지 판단할 수도 있다. 가령, 변환 네트워크의 추론 단계에서 변환 네트워크에 의해 생성된 속성 변환 데이터를 기초로 변환 이미지 데이터를 획득하고, 획득된 속성 변환 데이터를 기초로 변환 이미지 데이터가 타겟 속성 값을 포함하는지 판단할 수 있다.
이상에서, 전자 장치(100)를 통해 수행되는 것으로 기재된 다양한 동작들은, 전자 장치의 제어 방법 내지는 동작 방법의 형태로 하나 이상의 전자 장치를 통해 수행될 수 있다.
한편, 이상에서 설명된 다양한 실시 예들은 소프트웨어(software), 하드웨어(hardware) 또는 이들의 조합된 것을 이용하여 컴퓨터 또는 이와 유사한 장치로 읽을 수 있는 기록 매체 내에서 구현될 수 있다.
하드웨어적인 구현에 의하면, 본 개시에서 설명되는 실시 예들은 ASICs(Application Specific Integrated Circuits), DSPs(digital signal processors), DSPDs(digital signal processing devices), PLDs(Programmable logic devices), FPGAs(field programmable gate arrays), 프로세서(processor), 제어기(controller), 마이크로 컨트롤러(micro-controllers), 마이크로 프로세서(microprocessor), 기타 기능 수행을 위한 전기적인 유닛(unit) 중 적어도 하나를 이용하여 구현될 수 있다.
일부의 경우에 본 명세서에서 설명되는 실시 예들이 프로세서 자체로 구현될 수 있다. 소프트웨어적인 구현에 의하면 본 명세서에서 설명되는 절차 및 기능과 같은 실시 예들은 별도의 소프트웨어 모듈들로 구현될 수 있다. 상술한 소프트웨어 모듈들 각각은 본 명세서에서 설명되는 하나 이상의 기능 및 작동을 수행할 수 있다.
한편, 상술한 본 개시의 다양한 실시 예들에 따른 사용자 장치 또는 관리자 장치에서의 처리동작을 수행하기 위한 컴퓨터 명령어(computer instructions)는 비일시적 컴퓨터 판독 가능 매체(non-transitory computer-readable medium)에 저장될 수 있다. 이러한 비일시적 컴퓨터 판독 가능 매체에 저장된 컴퓨터 명령어는 특정 기기의 프로세서에 의해 실행되었을 때 상술한 다양한 실시 예에 따른 사용자 장치 및/또는 관리자 장치의 처리 동작을 상술한 특정 기기가 수행하도록 한다.
비일시적 판독 가능 매체란 레지스터, 캐쉬, 메모리 등과 같이 짧은 순간 동안 데이터를 저장하는 매체가 아니라 반영구적으로 데이터를 저장하며, 기기에 의해 판독(reading)이 가능한 매체를 의미한다. 구체적으로는, 상술한 다양한 어플리케이션 또는 프로그램들은 CD, DVD, 하드 디스크, 블루레이 디스크, USB, 메모리카드, ROM 등과 같은 비일시적 판독 가능 매체에 저장되어 제공될 수 있다.
또한, 이상에서는 본 개시의 바람직한 실시 예에 대하여 도시하고 설명하였지만, 본 개시는 상술한 특정의 실시 예에 한정되지 아니하며, 청구범위에서 청구하는 본 개시의 요지를 벗어남이 없이 당해 개시가 속하는 기술분야에서 통상의 지식을 가진 자에 의해 다양한 변형실시가 가능한 것은 물론이고, 이러한 변형실시들은 본 개시의 기술적 사상이나 전망으로부터 개별적으로 이해돼서는 안 될 것이다.
100: 전자 장치 110: 메모리
120: 프로세서 11: 이미지
12: 변환 이미지 20: 잠재공간

Claims (17)

  1. 전자 장치에 있어서,
    기생성된 잠재 공간에 관한 정보가 저장된 메모리; 및
    이미지를 상기 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 상기 잠재 공간 상의 이미지 데이터로 변환하고,
    상기 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하며,
    상기 이미지 데이터 및 상기 속성 변환 데이터를 기초로, 상기 이미지 데이터에 대한 변환 이미지 데이터를 생성하고,
    상기 변환 이미지 데이터를 기초로 상기 입력 이미지에 대한 변환 이미지를 생성하는 프로세서;를 포함하고,
    상기 속성 변환 데이터 및 상기 변환 이미지 데이터는 상기 잠재 공간 상의 데이터인, 전자 장치.
  2. 제1항에 있어서,
    상기 프로세서는,
    상기 타겟 속성 값을 입력 받고,
    상기 이미지 데이터에 포함된 복수의 속성 값 중 상기 타겟 속성 값에 대응되는 속성 값을 식별하고,
    상기 타겟 속성 값 및 상기 속성 값의 차이를 이용하여 상기 이미지 데이터의 변환을 판단하고,
    상기 타겟 속성 값 및 상기 속성 값의 차이를 기초로 상기 속성 변환 데이터를 추출하는, 전자 장치.
  3. 제2항에 있어서,
    상기 메모리는,
    상기 잠재 공간 상의 이미지 데이터, 상기 속성 값 및 상기 타겟 속성 값을 이용하여, 상기 속성 변환 데이터를 출력하도록 학습된 제1 인공지능 모델을 포함하고,
    상기 프로세서는, 상기 제1 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값을 입력하여 상기 속성 변환 데이터를 추출하는, 전자 장치.
  4. 제3항에 있어서,
    상기 제1 인공지능 모델은,
    상기 제1 인공지능 모델의 학습 시, 상기 제1 인공지능 모델에 입력된 이미지 데이터의 속성 값을 타겟 속성 값으로 변환하기 위한 속성 변환 데이터의 분포를 학습하고,
    상기 제1 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값이 입력되면, 상기 속성 변환 데이터의 분포를 판단하고, 상기 판단된 속성 변환 데이터의 분포에서 기 설정된 조건을 만족하는 속성 변환 데이터를 추출하는, 전자 장치.
  5. 제4항에 있어서,
    상기 메모리는,
    상기 이미지의 속성 값 및 상기 타겟 속성 값을 이용하여, 이미지에서의 속성 변환 데이터의 기준 분포를 출력하도록 학습된 제2 인공지능 모델을 포함하고,
    상기 프로세서는,
    상기 제2 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값을 입력하여 상기 속성 변환 데이터의 기준 분포를 획득하고,
    상기 획득된 기준 분포를 이용하여 상기 제1 인공지능 모델을 학습시키는, 전자 장치.
  6. 제3항에 있어서,
    상기 메모리는,
    입력된 이미지 데이터에 포함된 이미지의 속성 값을 출력하도록 학습된 제3 인공지능 모델을 포함하고,
    상기 프로세서는,
    상기 제3 인공지능 모델을 이용하여 상기 제1 인공지능 모델에 의하여 획득된 속성 변환 데이터를 기초로 생성된 변환 이미지 데이터가 타겟 속성 값을 포함하는지 판단하는, 전자 장치.
  7. 제3항에 있어서,
    상기 메모리는,
    상기 입력 이미지를 상기 이미지 데이터로 변환하도록 학습된 함수를 포함하는 제4 인공지능 모델을 포함하고,
    상기 잠재 공간은, 상기 제4 인공지능 모델이 복수의 이미지를 복수의 이미지 데이터로 변환하도록 학습하면서 생성되는 공간인, 전자 장치.
  8. 제1항에 있어서,
    상기 프로세서는,
    상기 함수의 역함수를 생성하고,
    상기 잠재 공간 상의 변환 이미지 데이터를 상기 역함수의 입력으로 하여 상기 이미지에 대한 변환 이미지를 생성하는, 전자 장치.
  9. 전자 장치의 제어 방법에 있어서,
    이미지를 기생성된 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 상기 잠재 공간 상의 이미지 데이터로 변환하는 단계;
    상기 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하는 단계;
    상기 이미지 데이터 및 상기 속성 변환 데이터를 기초로, 상기 이미지 데이터에 대한 변환 이미지 데이터를 생성하는 단계; 및
    상기 변환 이미지 데이터를 기초로 상기 입력 이미지에 대한 변환 이미지를 생성하는 단계;를 포함하고,
    상기 속성 변환 데이터 및 상기 변환 이미지 데이터는 상기 잠재 공간 상의 데이터인, 제어 방법.
  10. 제9항에 있어서,
    상기 타겟 속성 값을 입력 받는 단계; 및
    상기 이미지 데이터에 포함된 복수의 속성 값 중 상기 타겟 속성 값에 대응되는 속성 값을 식별하는 단계;를 더 포함하고,
    상기 속성 변환 데이터를 획득하는 단계는,
    상기 타겟 속성 값 및 상기 속성 값의 차이를 이용하여 상기 이미지 데이터의 변환을 판단하는 단계; 및
    상기 타겟 속성 값 및 상기 속성 값의 차이를 기초로 상기 속성 변환 데이터를 추출하는 단계;를 포함하는, 제어 방법.
  11. 제10항에 있어서,
    상기 추출하는 단계는,
    상기 속성 변환 데이터를 출력하도록 학습된 제1 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값을 입력하여 상기 속성 변환 데이터를 추출하는 단계;를 포함하는, 제어 방법.
  12. 제11항에 있어서,
    상기 제1 인공지능 모델은,
    상기 제1 인공지능 모델의 학습 시, 상기 이미지 데이터의 속성 값을 타겟 속성 값으로 변환하기 위한 속성 변환 데이터의 분포를 학습하고,
    상기 제1 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값이 입력되면, 상기 속성 변환 데이터의 분포를 판단하고, 상기 판단된 속성 변환 데이터의 분포에서 기 설정된 조건을 만족하는 속성 변환 데이터를 추출하는, 제어 방법.
  13. 제12항에 있어서,
    상기 이미지의 속성 값 및 상기 타겟 속성 값을 이용하여, 속성 변환 데이터의 기준 분포를 출력하도록 학습된 제2 인공지능 모델에 상기 속성 값 및 상기 타겟 속성 값의 차이 값을 입력하여 상기 속성 변환 데이터의 기준 분포를 획득하는 단계; 및
    상기 획득된 기준 분포를 이용하여 상기 제1 인공지능 모델을 학습시키는 단계;를 더 포함하는, 제어 방법.
  14. 제11항에 있어서,
    이미지 데이터를 입력 받아 이미지 데이터에 포함된 이미지의 속성 값을 출력하도록 학습된 제3 인공지능 모델을 이용하여, 상기 제1 인공지능 모델에 의하여 획득된 속성 변환 데이터를 기초로 생성된 변환 이미지 데이터가 타겟 속성 값을 포함하는지 판단하는 단계;를 더 포함하는, 제어 방법.
  15. 제11항에 있어서,
    상기 잠재 공간은,
    상기 입력 이미지를 상기 이미지 데이터로 변환하도록 학습된 함수를 포함하는 제4 인공지능 모델이 이미지를 이미지 데이터로 변환하도록 학습하면서 생성하는 공간인, 제어 방법.
  16. 제9항에 있어서,
    상기 변환 이미지를 생성하는 단계는,
    상기 함수의 역함수를 생성하는 단계; 및
    상기 잠재 공간 상의 변환 이미지 데이터를 상기 역함수의 입력으로 하여 상기 입력 이미지에 대한 변환 이미지를 생성하는 단계;를 포함하는, 제어 방법.
  17. 전자 장치의 제어 방법을 실행하기 위한 프로그램을 포함하는 컴퓨터 판독가능 기록매체에 있어서,
    이미지를 기생성된 잠재 공간 상의 데이터로 정규화하는 함수를 이용하여 입력 이미지를 상기 잠재 공간 상의 이미지 데이터로 변환하는 단계;
    상기 이미지 데이터에 포함된 이미지의 속성 값을 타겟 속성 값으로 변경하기 위한 속성 변환 데이터를 획득하는 단계; 및
    상기 이미지 데이터 및 상기 속성 변환 데이터를 기초로, 상기 이미지 데이터에 대한 변환 이미지 데이터를 생성하는 단계;를 포함하고,
    상기 속성 변환 데이터 및 상기 변환 이미지 데이터는 상기 잠재 공간 상의 데이터인, 컴퓨터 판독가능 기록매체.
KR1020200074103A 2020-06-18 2020-06-18 전자 장치 및 이의 제어 방법 KR20210156470A (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020200074103A KR20210156470A (ko) 2020-06-18 2020-06-18 전자 장치 및 이의 제어 방법
PCT/KR2021/005652 WO2021256702A1 (ko) 2020-06-18 2021-05-06 전자 장치 및 이의 제어 방법

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020200074103A KR20210156470A (ko) 2020-06-18 2020-06-18 전자 장치 및 이의 제어 방법

Publications (1)

Publication Number Publication Date
KR20210156470A true KR20210156470A (ko) 2021-12-27

Family

ID=79177305

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020200074103A KR20210156470A (ko) 2020-06-18 2020-06-18 전자 장치 및 이의 제어 방법

Country Status (2)

Country Link
KR (1) KR20210156470A (ko)
WO (1) WO2021256702A1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102543461B1 (ko) * 2022-04-29 2023-06-14 주식회사 이너버즈 딥 러닝을 이용하여 특정한 속성을 선별적으로 변화시키는 이미지 조정 방법

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7925081B2 (en) * 2007-12-12 2011-04-12 Fuji Xerox Co., Ltd. Systems and methods for human body pose estimation
KR102067340B1 (ko) * 2018-07-16 2020-01-16 한국과학기술원 유방암 병변 특성에 따른 유방 종괴 생성 방법 및 그 시스템
JP2020046984A (ja) * 2018-09-19 2020-03-26 株式会社Ye Digital 画像生成方法、画像判定方法、画像生成装置および画像生成プログラム
US11455790B2 (en) * 2018-11-14 2022-09-27 Nvidia Corporation Style-based architecture for generative neural networks
KR102316678B1 (ko) * 2018-11-19 2021-10-25 고려대학교 산학협력단 설명 가능한 소수샷 영상 분류 방법 및 장치

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102543461B1 (ko) * 2022-04-29 2023-06-14 주식회사 이너버즈 딥 러닝을 이용하여 특정한 속성을 선별적으로 변화시키는 이미지 조정 방법
KR102571082B1 (ko) * 2022-04-29 2023-08-28 주식회사 이너버즈 이미지 조정 방법

Also Published As

Publication number Publication date
WO2021256702A1 (ko) 2021-12-23

Similar Documents

Publication Publication Date Title
US11443462B2 (en) Method and apparatus for generating cartoon face image, and computer storage medium
US10607065B2 (en) Generation of parameterized avatars
US10223838B2 (en) Method and system of mobile-device control with a plurality of fixed-gradient focused digital cameras
JP2019510325A (ja) マルチモーダルデジタル画像を生成する方法及びシステム
US20220217269A1 (en) Electronic device and controlling method of electronic device
KR102118519B1 (ko) 전자 장치 및 그 제어 방법
US11294457B2 (en) Display apparatus and controlling method thereof
Li et al. Carigan: Caricature generation through weakly paired adversarial learning
WO2020134436A1 (zh) 生成动画表情的方法和电子设备
KR102668172B1 (ko) 메시징 시스템에서의 증강 현실 경험을 위한 물리적 제품들의 식별
US20210312533A1 (en) Identification of physical products for augmented reality experiences in a messaging system
KR102152120B1 (ko) 기계학습 모델을 이용하여 n개의 프레임에 기초하여 대상의 감정인식을 수행하는 감정인식 시스템, 방법, 및 컴퓨터-판독가능매체
US20220101144A1 (en) Training a latent-variable generative model with a noise contrastive prior
US20210312678A1 (en) Generating augmented reality experiences with physical products using profile information
JP2019219914A (ja) 画像生成装置、画像生成器、画像識別器、画像生成プログラム、及び、画像生成方法
KR20210062477A (ko) 전자 장치 및 그 제어 방법
US11403799B2 (en) Method and apparatus for recognizing face-swap, device and computer readable storage medium
US20210232863A1 (en) Electronic device and controlling method of electronic device
US11328385B2 (en) Automatic image warping for warped image generation
KR20210156470A (ko) 전자 장치 및 이의 제어 방법
JP2022002093A (ja) 顔編集方法、装置、電子デバイス及び可読記憶媒体
CN115170455B (zh) 图像处理方法及相关装置
US11875601B2 (en) Meme generation method, electronic device and storage medium
US20210201142A1 (en) Electronic device and control method thereof
US11423308B1 (en) Classification for image creation