KR20220117569A - 전자 장치 및 전자 장치의 제어 방법 - Google Patents
전자 장치 및 전자 장치의 제어 방법 Download PDFInfo
- Publication number
- KR20220117569A KR20220117569A KR1020210021074A KR20210021074A KR20220117569A KR 20220117569 A KR20220117569 A KR 20220117569A KR 1020210021074 A KR1020210021074 A KR 1020210021074A KR 20210021074 A KR20210021074 A KR 20210021074A KR 20220117569 A KR20220117569 A KR 20220117569A
- Authority
- KR
- South Korea
- Prior art keywords
- data
- memory
- files
- electronic device
- server
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1446—Point-in-time backing up or restoration of persistent data
- G06F11/1458—Management of the backup or restore process
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/602—Providing cryptographic facilities or services
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6245—Protecting personal data, e.g. for financial or medical purposes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/451—Execution arrangements for user interfaces
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V10/00—Arrangements for image or video recognition or understanding
- G06V10/10—Image acquisition
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V10/00—Arrangements for image or video recognition or understanding
- G06V10/40—Extraction of image or video features
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/40—Support for services or applications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/34—Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Bioethics (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Computer Hardware Design (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Human Computer Interaction (AREA)
- Quality & Reliability (AREA)
- Medical Informatics (AREA)
- Databases & Information Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
전자 장치 및 전자 장치의 제어 방법이 개시된다. 특히, 본 개시에 따른 전자 장치의 제어 방법은 전자 장치의 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계, 메모리의 잔여 용량이 식별된 제1 데이터의 크기 미만이면, 메모리에서 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하는 단계, 식별된 제2 데이터를 제1 서버로 전송하는 단계, 전송된 제2 데이터를 메모리에서 삭제하는 단계, 제2 데이터가 메모리에서 삭제되면, 제2 서버로부터 제1 데이터를 수신하여 메모리에 저장하는 단계, 메모리에 저장된 제1 데이터를 바탕으로 소프트웨어를 업데이트하는 단계 및 소프트웨어의 업데이트가 완료되면, 제1 서버로부터 제2 데이터를 수신하여 메모리에 저장하는 단계를 포함한다.
Description
본 개시는 전자 장치 및 전자 장치의 제어 방법에 관한 것으로서, 구체적으로는 소프트웨어의 업데이트를 원활하게 수행할 수 있는 전자 장치 및 전자 장치의 제어 방법을 제공함에 있다.
근래에는 사용자가 전자 장치를 구입한 후에도 지속적으로 개선된 사용자 경험을 누릴 수 있도록, 제조사/개발사에 의해 소프트웨어 업데이트를 위한 서비스가 활발하게 제공되고 있다.
그런데, 소프트웨어의 업데이트를 수행할 때 전자 장치에 소프트웨어의 업데이트를 위해 필요한 데이터를 저장할 수 있는 공간이 확보되어 있지 않은 경우에는, 소프트웨어의 업데이트가 원활하게 수행될 수 없게 되며, 이에 따라 사용자는 각종 버그의 수정 또는 신규 기능 등과 같은 혜택을 경험하지 못하게 될 수 있다.
그리고, 소프트웨어의 취약한 보안성을 개선하기 위한 경우와 같이 신속한 업데이트가 필요한 경우에는 사용자의 확인 없이 소프트웨어의 업데이트를 강제하기도 하지만, 이 경우에도 전자 장치에 소프트웨어의 업데이트를 위해 필요한 데이터를 저장할 수 있는 공간이 확보되어 있지 않다면, 사용자가 직접 공간을 확보하지 않는 한 소프트웨어의 업데이트가 수행될 수 없다. 그리고, 이와 같은 경우에는 보안 사고의 발생 또는 기업 신뢰도의 하락이 초래될 수도 있다.
상술한 바와 같은 문제를 해결하기 위해, 종래 기술의 경우 소프트웨어의 업데이트를 수행하기에 앞서 일률적으로 전자 장치에 저장된 파일들을 외부 장치에 백업하거나, 사용자에게 직접 저장 공간을 확보하도록 요청하는 등의 방식으로 상술한 바와 같은 문제를 해결하고 있다. 그러나, 종래 기술에 대해서는 데이터의 백업 과정에 대한 효율성이 떨어진다는 점, 데이터의 백업 과정에서 보안성을 확보하기 어렵다는 점, 데이터의 백업 과정에 대한 사용자의 신뢰성과 편의성이 높지 않다는 점 등과 같은 한계가 지적되고 있다.
본 개시는 상술한 바와 같은 종래 기술의 한계를 극복하기 위한 것으로서, 본 개시의 목적은 전자 장치에 소프트웨어의 업데이트를 위해 필요한 데이터를 저장할 수 있는 공간이 확보되어 있지 않은 경우에도 효율적이고도 신뢰할 수 있는 방법으로 소프트웨어의 업데이트를 원활하게 수행할 수 있는 전자 장치 및 전자 장치의 제어 방법을 제공함에 있다.
상술한 바와 같은 목적을 달성하기 위한 본 개시의 일 실시 예에 따르면, 전자 장치는 통신 모듈, 메모리 및 상기 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하고, 상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하고, 상기 식별된 제2 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어하며, 상기 전송된 제2 데이터를 상기 메모리에서 삭제하고, 상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 통신 모듈을 통해 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하며, 상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하고, 상기 소프트웨어의 업데이트가 완료되면, 상기 통신 모듈을 통해 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 프로세서를 포함한다.
여기서, 상기 제2 데이터는 적어도 하나의 파일을 포함하고, 상기 프로세서는 기 정의된 복수의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하며, 상기 복수의 결정 기준은 상기 메모리에서 상기 복수의 파일이 저장된 위치, 상기 복수의 파일의 크기, 상기 복수의 파일이 상기 메모리에 저장된 시간, 상기 복수의 파일의 형식, 상기 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 상기 복수의 파일의 중요도 중 적어도 하나를 포함할 수 있다.
여기서, 상기 프로세서는 상기 복수의 파일 중 적어도 하나의 인물을 포함하는 이미지 파일이 식별되면, 상기 이미지 파일이 상기 사용자 프라이버시에 관련된 정보를 포함하는 것으로 식별하고, 상기 복수의 파일이 적어도 하나의 인물을 포함하는지 여부는 상기 복수의 파일 각각에 대한 메타데이터 및 상기 복수의 파일 각각을 객체 인식 모델에 입력함에 따라 획득된 객체 인식 결과 중 적어도 하나를 바탕으로 식별될 수 있다.
한편, 상기 프로세서는 상기 복수의 파일 별로 상기 복수의 결정 기준 각각에 대한 스코어를 획득하고, 상기 복수의 결정 기준 각각에 대한 스코어를 바탕으로 상기 복수의 파일 별 종합 스코어를 획득하며, 상기 복수의 파일 중 상기 종합 스코어가 기 설정된 임계 값 이상인 하나 이상의 파일을 상기 적어도 하나의 파일로 식별할 수 있다.
한편, 상기 프로세서는 상기 제2 데이터가 식별되면, 상기 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하고, 상기 제3 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어하며, 상기 소프트웨어의 업데이트가 완료되면, 상기 통신 모듈을 통해 상기 제1 서버로부터 상기 제3 데이터를 수신하고, 상기 수신된 제3 데이터를 복호화하여 상기 제2 데이터를 획득하며, 상기 획득된 제2 데이터를 상기 메모리에 저장할 수 있다.
한편, 상기 소프트웨어를 업데이트하기 위한 요청은 상기 통신 모듈을 통해 상기 제2 서버로 전송된 업데이트 확인 요청에 따라 상기 제2 서버로부터 수신된 응답 또는 상기 소프트웨어를 업데이트하기 위한 제1 사용자 입력을 바탕으로 수신될 수 있다.
한편, 상기 전자 장치는 디스플레이 모듈을 더 포함하고, 상기 프로세서는 상기 잔여 용량이 상기 식별된 크기 미만이면, 상기 메모리에 저장된 복수의 파일 중 적어도 일부 파일에 대한 리스트를 포함하는 제1 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고, 상기 제1 사용자 인터페이스를 통해 상기 적어도 일부 파일 중 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력을 수신하고, 상기 제2 사용자 입력을 바탕으로 상기 제2 데이터를 식별할 수 있다.
여기서, 상기 프로세서는 상기 제2 데이터가 식별되면, 상기 잔여 용량이 상기 식별된 크기 미만이라는 정보를 포함하는 제2 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고, 상기 제2 사용자 인터페이스를 통해 상기 제2 데이터를 상기 제1 서버로 전송하기 위한 제3 사용자 입력이 수신되면, 상기 제2 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어할 수 있다.
한편, 상기 프로세서는 상기 복수의 결정 기준에 대한 리스트를 포함하는 제3 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고, 상기 제3 사용자 인터페이스를 통해 상기 복수의 결정 기준 중 적어도 하나의 결정 기준을 선택하는 제4 사용자 입력이 수신되면, 상기 적어도 하나의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별할 수 있다.
상술한 바와 같은 목적을 달성하기 위한 본 개시의 일 실시 예에 따르면, 전자 장치의 제어 방법은 상기 전자 장치의 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계, 상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하는 단계, 상기 식별된 제2 데이터를 상기 제1 서버로 전송하는 단계, 상기 전송된 제2 데이터를 상기 메모리에서 삭제하는 단계, 상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하는 단계, 상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하는 단계 및 상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 단계를 포함한다.
여기서, 상기 제2 데이터는 적어도 하나의 파일을 포함하고, 상기 제2 데이터를 식별하는 단계는 기 정의된 복수의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하는 단계를 포함하며, 상기 복수의 결정 기준은 상기 메모리에서 상기 복수의 파일이 저장된 위치, 상기 복수의 파일의 크기, 상기 복수의 파일이 상기 메모리에 저장된 시간, 상기 복수의 파일의 형식, 상기 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 상기 복수의 파일의 중요도 중 적어도 하나를 포함할 수 있다.
여기서, 상기 제2 데이터를 식별하는 단계는 상기 복수의 파일 중 적어도 하나의 인물을 포함하는 이미지 파일이 식별되면, 상기 이미지 파일이 상기 사용자 프라이버시에 관련된 정보를 포함하는 것으로 식별하는 단계를 더 포함하고, 상기 복수의 파일이 적어도 하나의 인물을 포함하는지 여부는 상기 복수의 파일 각각에 대한 메타데이터 및 상기 복수의 파일 각각을 객체 인식 모델에 입력함에 따라 획득된 객체 인식 결과 중 적어도 하나를 바탕으로 식별될 수 있다.
한편, 상기 제2 데이터를 식별하는 단계는 상기 복수의 파일 별로 상기 복수의 결정 기준 각각에 대한 스코어를 획득하는 단계, 상기 복수의 결정 기준 각각에 대한 스코어를 바탕으로 상기 복수의 파일 별 종합 스코어를 획득하는 단계 및 상기 복수의 파일 중 상기 종합 스코어가 기 설정된 임계 값 이상인 하나 이상의 파일을 상기 적어도 하나의 파일로 식별하는 단계를 더 포함할 수 있다.
한편, 상기 전자 장치의 제어 방법은 상기 제2 데이터가 식별되면, 상기 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하는 단계, 상기 제3 데이터를 상기 제1 서버로 전송하는 단계, 상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제3 데이터를 수신하는 단계, 상기 수신된 제3 데이터를 복호화하여 상기 제2 데이터를 획득하는 단계 및 상기 획득된 제2 데이터를 상기 메모리에 저장하는 단계를 더 포함할 수 있다.
한편, 상기 소프트웨어를 업데이트하기 위한 요청은 상기 제2 서버로 전송된 업데이트 확인 요청에 따라 상기 제2 서버로부터 수신된 응답 또는 상기 소프트웨어를 업데이트하기 위한 제1 사용자 입력을 바탕으로 수신될 수 있다.
한편, 상기 전자 장치의 제어 방법은 상기 잔여 용량이 상기 식별된 크기 미만이면, 상기 메모리에 저장된 복수의 파일 중 적어도 일부 파일에 대한 리스트를 포함하는 제1 사용자 인터페이스를 표시하는 단계, 상기 제1 사용자 인터페이스를 통해 상기 적어도 일부 파일 중 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력을 수신하는 단계 및 상기 제2 사용자 입력을 바탕으로 상기 제2 데이터를 식별하는 단계를 더 포함할 수 있다.
여기서, 상기 전자 장치의 제어 방법은 상기 제2 데이터가 식별되면, 상기 잔여 용량이 상기 식별된 크기 미만이라는 정보를 포함하는 제2 사용자 인터페이스를 표시하는 단계 및 상기 제2 사용자 인터페이스를 통해 상기 제2 데이터를 상기 제1 서버로 전송하기 위한 제3 사용자 입력이 수신되면, 상기 제2 데이터를 상기 제1 서버로 전송하는 단계를 더 포함할 수 있다.
한편, 상기 전자 장치의 제어 방법은 상기 복수의 결정 기준에 대한 리스트를 포함하는 제3 사용자 인터페이스를 표시하는 단계 및 상기 제3 사용자 인터페이스를 통해 상기 복수의 결정 기준 중 적어도 하나의 결정 기준을 선택하는 제4 사용자 입력이 수신되면, 상기 적어도 하나의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하는 단계를 더 포함할 수 있다.
상술한 바와 같은 목적을 달성하기 위한 본 개시의 일 실시 예에 따르면, 전자 장치의 제어 방법을 실행하는 프로그램을 포함하는 비일시적 컴퓨터 판독 가능 기록매체에 있어서, 상기 전자 장치의 제어 방법은 상기 전자 장치의 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계, 상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하는 단계, 상기 식별된 제2 데이터를 상기 제1 서버로 전송하는 단계, 상기 전송된 제2 데이터를 상기 메모리에서 삭제하는 단계, 상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하는 단계, 상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하는 단계 및 상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 단계를 포함한다.
도 1은 본 개시의 일 실시 예에 따른 전자 장치의 하드웨어 구성을 간략하게 나타내는 블록도,
도 2는 본 개시의 일 실시 예에 따른 소프트웨어 모듈들을 상세하게 나타내는 도면,
도 3은 본 개시의 일 실시 예에 따른 전자 장치, 제1 서버 및 제2 서버의 동작을 구체적으로 나타내는 시퀀스도,
도 4는 본 개시에 따른 전자 장치의 하드웨어 구성을 상세하게 나타내는 도면,
도 5는 본 개시의 일 실시 예에 따른 제1 사용자 인터페이스의 일 예를 나타내는 도면,
도 6a 및 도 6b는 본 개시의 일 실시 예에 따른 제2 사용자 인터페이스의 일 예를 나타내는 도면,
도 7은 본 개시의 일 실시 예에 따른 제3 사용자 인터페이스의 일 예를 나타내는 도면, 그리고,
도 8은 본 개시의 일 실시 예에 따른 전자 장치의 제어 방법을 나타내는 흐름도이다.
도 2는 본 개시의 일 실시 예에 따른 소프트웨어 모듈들을 상세하게 나타내는 도면,
도 3은 본 개시의 일 실시 예에 따른 전자 장치, 제1 서버 및 제2 서버의 동작을 구체적으로 나타내는 시퀀스도,
도 4는 본 개시에 따른 전자 장치의 하드웨어 구성을 상세하게 나타내는 도면,
도 5는 본 개시의 일 실시 예에 따른 제1 사용자 인터페이스의 일 예를 나타내는 도면,
도 6a 및 도 6b는 본 개시의 일 실시 예에 따른 제2 사용자 인터페이스의 일 예를 나타내는 도면,
도 7은 본 개시의 일 실시 예에 따른 제3 사용자 인터페이스의 일 예를 나타내는 도면, 그리고,
도 8은 본 개시의 일 실시 예에 따른 전자 장치의 제어 방법을 나타내는 흐름도이다.
본 실시 예들은 다양한 변환을 가할 수 있고 여러 가지 실시 예를 가질 수 있는바, 특정 실시 예들을 도면에 예시하고 상세한 설명에 상세하게 설명하고자 한다. 그러나 이는 특정한 실시 형태에 대해 범위를 한정하려는 것이 아니며, 본 개시의 실시 예의 다양한 변경(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 또는 application processor)를 의미할 수 있다.
실시 예에 있어서 '모듈' 혹은 '부'는 적어도 하나의 기능이나 동작을 수행하며, 하드웨어 또는 소프트웨어로 구현되거나 하드웨어와 소프트웨어의 결합으로 구현될 수 있다. 또한, 복수의 '모듈' 혹은 복수의 '부'는 특정한 하드웨어로 구현될 필요가 있는 '모듈' 혹은 '부'를 제외하고는 적어도 하나의 모듈로 일체화되어 적어도 하나의 프로세서로 구현될 수 있다.
한편, 도면에서의 다양한 요소와 영역은 개략적으로 그려진 것이다. 따라서, 본 발명의 기술적 사상은 첨부한 도면에 그려진 상대적인 크기나 간격에 의해 제한되지 않는다.
본 문서에 개시된 다양한 실시 예들에 따른 전자 장치는 다양한 형태의 장치가 될 수 있다. 전자 장치는, 예를 들면, 휴대용 통신 장치(예: 스마트폰), 컴퓨터 장치, 휴대용 멀티미디어 장치, 휴대용 의료 기기, 카메라, 웨어러블 장치, 또는 가전 장치를 포함할 수 있다. 본 문서의 실시 예에 따른 전자 장치는 전술한 기기들에 한정되지 않는다.
이하에서는 첨부한 도면을 참고하여 본 개시에 따른 실시 예에 대하여 본 개시가 속하는 기술 분야에서 통상의 지식을 가진 자가 용이하게 실시할 수 있도록 상세히 설명한다.
도 1은 본 개시의 일 실시 예에 따른 전자 장치(100)의 하드웨어 구성을 간략하게 나타내는 블록도이다.
이하에서는 먼저 본 개시를 설명함에 있어서 사용되는 주요 용어에 대해 설명한 후 본 개시의 다양한 실시 예에 대해 설명한다.
본 개시를 설명함에 있어서, '제1 데이터'는 소프트웨어의 업데이트를 위해 필요한 데이터를 총칭하기 위한 용어로 사용된다. 구체적으로, 제1 데이터는 제1 버전의 소프트웨어를 제2 버전의 소프트웨어로 업데이트하기 위해 필요한 델타 파일(delta file)일 수도 있다. 여기서, '델타 파일'이란 제1 버전의 소프트웨어를 기준으로 제2 버전의 소프트웨어에서 변경된 부분에 대응되는 파일, 즉 제1 버전의 소프트웨어와 제2 버전의 소프트웨어 사이의 차이에 해당하는 부분만을 추출한 파일을 말한다. 한편, 제1 데이터는 제2 버전의 소프트웨어를 구성하는 전체 파일을 의미할 수도 있으나, 이하에서는 설명의 편의를 위해, 제1 데이터라는 용어를 델타 파일을 지칭하기 위한 용어로 사용한다.
'제2 데이터'는 소프트웨어 업데이트를 위한 용량을 확보하기 위해 임시로 백업될 데이터를 총칭하기 위한 용어로 사용된다. 구체적으로, 제2 데이터는 전자 장치(100)에 저장된 적어도 하나의 파일을 포함할 수 있으며, 예를 들어 이미지 파일, 음악 파일, 문서 파일 등과 같은 다양한 파일을 포함할 수 있다.
'제1 서버(200)'란 본 개시에 따른 제2 데이터를 백업하기 위한 서버를 말한다. 구체적으로, 제1 서버(200)는 제2 데이터만을 백업하기 위한 독립적인 클라우드 서버일 수도 있으나, 이에 국한되는 것은 아니다. 즉, 제1 서버(200)는 전자 장치(100)의 사용자가 전자 장치(100)에 저장된 파일들을 동기화하기 위해 이용하는 클라우드 서버일 수도 있다.
'제2 서버(300)'란 본 개시에 따른 제1 데이터를 제공하기 위한 서버를 말한다. 이하에서는 명확한 설명을 위해 제2 서버(300)가 제1 서버(200)와는 별개의 서버로 구현되는 경우를 전제로 설명할 것이지만, 본 개시에 따른 제1 서버(200) 및 제2 서버(300)는 통합된 하나의 서버로 구현될 수도 있음은 물론이다.
도 1을 참조하면, 본 개시의 일 실시 예에 따른 전자 장치(100)는 통신 모듈(10), 메모리(20) 및 프로세서(30)를 포함할 수 있다. 다만, 도 1에 도시된 바와 같은 구성들은 예시적인 것에 불과할 뿐이며, 본 개시를 실시함에 있어 도 1에 도시된 바와 같은 구성에 더하여 새로운 구성이 추가되거나 일부 구성이 생략될 수 있음은 물론이다. 전자 장치(100)의 보다 구체적인 구성에 대해서는 도 4를 참조하여 보다 구체적으로 설명한다.
통신 모듈(10)은 회로를 포함하며, 외부 장치 또는 서버와의 통신을 수행할 수 있다. 특히, 통신 모듈(10)은 본 개시에 따른 제1 서버(200) 및 제2 서버(300)와의 통신을 수행할 수 있다. 통신 모듈(10)은 제1 서버(200)로 제2 데이터를 전송하여 제2 데이터를 백업할 수 있으며, 그 후 제1 서버(200)로부터 제2 데이터를 수신하여 제2 데이터를 복원할 수도 있다. 또한, 통신 모듈(10)은 제2 서버(300)로부터 제1 데이터를 수신할 수도 있다.
메모리(20)에는 전자 장치(100)에 관한 적어도 하나의 인스트럭션(instruction)이 저장될 수 있다. 그리고, 메모리(20)에는 전자 장치(100)를 구동시키기 위한 운영체제(Operating System, OS), 각종 소프트웨어 또는 애플리케이션이 저장될 수 있다. 또한, 메모리(20)에는 본 개시의 다양한 실시 예에 따라 전자 장치(100)가 동작하기 위한 각종 소프트웨어 모듈이 저장될 수 있으며, 프로세서(30)는 메모리(20)에 액세스하고 메모리(20)에 저장된 각종 소프트웨어 모듈을 실행함으로써 전자 장치(100)의 동작을 제어할 수 있다.
특히, 메모리(20)에는 본 개시에 따른 소프트웨어, 제1 데이터, 제2 데이터 및 제2 데이터를 식별하기 위한 복수의 결정 기준에 대한 정보 등이 저장될 수 있으며, 그 밖에도 본 개시의 목적을 달성하기 위한 범위 내에서 필요한 다양한 정보가 메모리(20)에 저장될 수 있다. 메모리(20)에 저장된 정보는 외부 장치로부터 수신되거나 사용자 입력이 수신됨에 따라 업데이트될 수도 있다.
프로세서(30)는 전자 장치(100)의 전반적인 동작을 제어할 수 있다. 구체적으로, 프로세서(30)는 통신 모듈(10) 및 메모리(20)를 포함하는 전자 장치(100)의 구성과 연결되며, 메모리(20)에 저장된 적어도 하나의 인스트럭션을 실행함으로써, 전자 장치(100)의 동작을 전반적으로 제어할 수 있다.
특히, 프로세서(30)는 메모리(20)에 저장된 소프트웨어를 업데이트하기 위한 요청을 수신할 수 있다. 일 실시 예에 따르면, 소프트웨어를 업데이트하기 위한 요청은 통신 모듈(10)을 통해 제2 서버(300)로 전송된 업데이트 확인 요청에 따라 제2 서버(300)로부터 수신된 응답을 바탕으로 수신될 수 있다. 구체적으로, 프로세서(30)는 메모리(20)에 저장된 소프트웨어가 최신 버전인지 여부에 대한 요청을 제2 서버(300)로 주기적으로 전송할 수 있으며, 제2 서버(300)는 그 요청에 응답할 수 있다. 여기서, 제2 서버(300)로부터 수신된 응답에는 메모리(20)에 저장된 소프트웨어가 최신 버전이 아니라는 정보 및 소프트웨어의 업데이트를 위해 필요한 제1 데이터의 크기에 대한 정보가 포함될 수 있다.
다른 실시 예에 따르면, 소프트웨어를 업데이트하기 위한 요청은 소프트웨어를 업데이트하기 위한 사용자 입력을 바탕으로 수신될 수 있다. 이하에서는 소프트웨어를 업데이트하기 위한 사용자 입력을 '제1 사용자 입력'이라고 지칭할 것이며, 이는 도 5 내지 도 7을 참조하여 후술하는 바와 같은 제2 사용자 입력, 제3 사용자 입력 및 제4 사용자 입력과의 구별을 위한 것이다. 구체적으로, 제2 서버(300)는 소프트웨어의 최신 버전에 대한 업데이트가 준비되었음을 나타내는 정보를 전자 장치(100)로 전송할 수 있다. 그리고, 프로세서(30)는 소프트웨어의 최신 버전에 대한 업데이트가 준비되었음을 나타내는 정보를 사용자에게 제공할 수 있으며, 이에 따라 소프트웨어를 업데이트하기 위한 사용자 입력이 수신될 수 있다.
소프트웨어를 업데이트하기 위한 요청이 수신되면, 프로세서(30)는 업데이트를 위해 필요한 제1 데이터의 크기를 식별할 수 있으며, 제1 데이터의 크기와 메모리(20)의 잔여 용량을 비교할 수 있다.
구체적으로, 프로세서(30)는 제2 서버(300)로부터 수신된 제1 데이터의 크기에 대한 정보를 바탕으로 제1 데이터의 크기를 식별하고, 제1 데이터의 크기와 메모리(20)의 잔여 용량을 비교함으로써, 소프트웨어를 업데이트하기 위한 메모리(20)의 공간이 확보되었는지 여부를 식별할 수 있다. 메모리(20)의 잔여 용량을 식별함에 있어서, 전자 장치(100)의 정상적인 구동을 위해 필수적으로 유지되어야 하는 만큼의 용량은 제외될 수도 있다.
메모리(20)의 잔여 용량이 식별된 제1 데이터의 크기 미만이면, 프로세서(30)는 메모리(20)에서 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버(200)에 백업될 제2 데이터를 식별할 수 있다.
여기서, 제2 데이터의 크기가 제1 데이터의 크기에 대응된다는 것은 제2 데이터의 크기가 제1 데이터의 크기와 동일한 경우뿐만 아니라, 제2 데이터의 크기가 제1 데이터의 크기보다 큰 경우를 포함할 수 있다. 다만, 제2 데이터의 크기가 제1 데이터의 크기보다 기 설정된 임계 값 이상으로 큰 경우에는 제2 데이터의 크기가 제1 데이터의 크기에 대응되지 않는 것으로 식별될 수 있다.
구체적으로, 프로세서(30)는 기 정의된 복수의 결정 기준을 바탕으로 메모리(20)에 저장된 복수의 파일 중 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 보다 구체적으로, 프로세서(30)는 복수의 파일 별로 복수의 결정 기준 각각에 대한 스코어를 획득하고 높은 스코어를 갖는 파일 순으로 제2 데이터에 포함시키는 방식으로, 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다.
여기서, 복수의 결정 기준은 메모리(20)에서 복수의 파일이 저장된 위치, 복수의 파일의 크기, 복수의 파일이 메모리(20)에 저장된 시간, 복수의 파일의 형식, 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 복수의 파일의 중요도 중 적어도 하나를 포함할 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일이 저장된 위치를 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 파일 중 기 지정된 특정 폴더에 포함된 파일들에 높은 스코어를 할당할 수 있다. 예를 들어, 외부 장치로부터 수신된 파일이 저장되는 폴더에 포함된 파일들에 높은 스코어를 할당할 수 있으며, 빈번하게 업데이트된 폴더에 포함된 파일들에 높은 스코어를 할당할 수도 있다. 예를 들어, 제1 파일이 외부 장치로부터 수신된 파일들이 저장되는 "다운로드 폴더"에 저장된 파일이고, 제2 파일이 카메라를 통해 획득된 이미지를 저장하는 "카메라 폴더"에 저장된 파일인 경우, 프로세서(30)는 제1 파일을 제2 데이터에 포함시키고 제2 파일은 제2 데이터에 포함시키지 않을 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일의 크기를 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 파일 중 파일의 크기가 큰 순서대로 높은 스코어를 할당할 수 있으며, 복수의 파일 중 제1 데이터의 크기에 대응되는 크기를 갖는 파일들에 높은 스코어를 할당할 수도 있다. 예를 들어, 제1 데이터의 크기가 500MB인 경우, 프로세서(30)는 530MB의 크기를 갖는 제1 파일 및 1GB(gigabyte)의 크기를 갖는 제2 파일 중 제1 파일을 제2 데이터에 포함시키고 제2 파일은 제2 데이터에 포함시키지 않을 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일이 메모리(20)에 저장된 시간을 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 파일 중 메모리(20)에 저장된 시간이 오래된 파일일수록 더 높은 스코어를 할당할 수 있다. 예를 들어, 제1 파일이 2년 전에 저장된 파일이고 제2 파일이 하루 전에 저장된 파일인 경우, 프로세서(30)는 제1 파일을 제2 데이터에 포함시키고 제2 파일은 제2 데이터에 포함시키지 않을 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일의 형식을 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 파일 중 기 지정된 형식에 대응되는 파일들에 높은 스코어를 할당할 수 있다. 이 경우, 파일의 형식은 각 파일의 확장자를 바탕으로 식별될 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부를 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다.
특히, 복수의 파일 중 적어도 하나의 인물을 포함하는 이미지 파일이 식별되면, 프로세서(30)는 그 이미지 파일이 사용자 프라이버시에 관련된 정보를 포함하는 것으로 식별할 수 있다. 여기서, 복수의 파일이 적어도 하나의 인물을 포함하는지 여부는 복수의 파일 각각에 대한 메타데이터 및 복수의 파일 각각을 객체 인식 모델(object recognition model)에 입력함에 따라 획득된 객체 인식 결과 중 적어도 하나를 바탕으로 식별될 수 있다. 여기서, 객체 인식 모델은 입력된 이미지가 기 정의된 복수의 클래스(도메인 또는 카테고리) 중 어떠한 클래스에 대응되는지 여부를 식별할 수 있도록 학습된 신경망 모델을 말한다.
한편, 프로세서(30)는 이미지 파일에 포함된 인물에 대한 정보를 획득하고, 그 인물에 대한 정보를 바탕으로 이미지 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부를 식별할 수 있다. 구체적으로, 프로세서(30)는 이미지 파일을 객체 인식 모델이 입력하여 이미지 파일에 포함된 인물을 식별하고, 기 저장된 연락처 정보 또는 인명 정보 등을 바탕으로 식별된 인물이 전자 장치(100)의 사용자인지 사용자와 상이한 타인인지 여부를 식별할 수 있다. 또한, 이미지 파일에 포함된 인물이 전자 장치(100)의 사용자가 아닌 타인이면, 프로세서(30)는 사용자와 타인 사이에 송수신된 메시지에 대한 정보 및 타인의 소셜 미디어에 관련된 어플리케이션을 통해 획득된 정보 등을 바탕으로 사용자와 타인 사이의 관계에 대한 정보를 획득할 수 있다. 그리고, 이미지 파일에 포함된 인물이 전자 장치(100)의 사용자 또는 사용자와 밀접한 관계에 있는 인물(예: 가족, 연인 등)이면, 프로세서(30)는 그 이미지 파일을 제2 데이터에 포함시키지 않을 수 있다.
일 실시 예에 따르면, 프로세서(30)는 복수의 파일의 중요도를 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 파일 중 사용자에 의해 북마크(bookmark)된 파일 또는 해시태그(hashtag)가 첨부된 파일 등과 같이, 사용자에 의해 중요한 파일로 취급된 히스토리가 있는 파일에 높은 스코어를 할당할 수 있다. 그 밖에도, 복수의 파일의 중요도는 다양한 기준들에 따라 결정될 수 있으며, 다양한 기준들 중 적어도 일부는 상술한 바와 같은 사용자 프라이버시에 대한 관련성 또는 파일이 저장된 위치 등과 중복될 수도 있다.
한편, 이상에서는 복수의 결정 기준 각각을 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별하는 과정에 대해 설명하였으나, 프로세서(30)는 상술한 바와 같은 복수의 결정 기준 중 두 가지 이상을 결합함으로써 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 구체적으로, 프로세서(30)는 복수의 결정 기준 각각에 대한 스코어를 바탕으로 복수의 파일 별 종합 스코어를 획득하고, 복수의 파일 중 종합 스코어가 기 설정된 임계 값 이상인 하나 이상의 파일을 제2 데이터에 포함되는 적어도 하나의 파일로 식별할 수 있다. 예를 들어, 프로세서(30)는 복수의 파일 중 "다운로드 폴더"에 저장된 파일들을 식별하고, "다운로드 폴더"에 저장된 파일들 중 제1 데이터의 크기에 대응되는 크기를 가지며 사용자 프라이버시에 관련된 정보를 포함하지 않는 파일을 우선적으로 제2 데이터에 포함시킬 수 있다.
한편, 이상에서는 복수의 결정 기준이 기 정의된 것을 전제로 설명하였으나, 이는 본 개시에 따른 다양한 실시 예를 상세하게 설명하기 위한 것일 뿐, 하나의 결정 기준만이 기 정의된 경우를 배제하기 위한 것은 아니다.
제2 데이터가 식별되면, 프로세서(30)는 식별된 제2 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어하고, 전송된 제2 데이터를 메모리(20)에서 삭제할 수 있다. 다시 말해, 프로세서(30)는 제2 데이터에 포함된 적어도 하나의 파일을 제1 서버(200)로 업로드한 후 제2 데이터에 포함된 적어도 하나의 파일을 삭제함으로써, 제1 데이터를 다운로드할 수 있는 메모리(20)의 공간을 확보할 수 있다.
한편, 제2 데이터를 제1 서버(200)로 전송하는 경우의 보안성을 확보하기 위해, 프로세서(30)는 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하고, 제3 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어할 수도 있다. 여기서, 암호화는 제3 데이터를 제2 데이터로 복호화하기 위한 비밀번호를 설정하는 방식으로 수행될 수도 있다.
제2 데이터가 메모리(20)에서 삭제되면, 프로세서(30)는 통신 모듈(10)을 통해 제2 서버(300)로부터 제1 데이터를 수신하여 메모리(20)에 저장할 수 있다. 그리고, 프로세서(30)는 메모리(20)에 저장된 제1 데이터를 바탕으로 소프트웨어를 업데이트할 수 있다. 다시 말해, 프로세서(30)는 제2 데이터를 삭제함으로써 확보된 메모리(20)의 공간에 제1 데이터를 다운로드한 후 제1 데이터를 바탕으로 소프트웨어를 업데이트할 수 있다.
소프트웨어의 업데이트가 완료되면, 프로세서(30)는 통신 모듈(10)을 통해 제1 서버(200)로부터 제2 데이터를 수신하여 메모리(20)에 저장할 수 있다. 다시 말해, 프로세서(30)는 소프트웨어의 업데이트가 완료된 후 제1 서버(200)에서 제2 데이터를 다운로드함으로써 제2 데이터를 복원할 수 있다.
구체적으로, 제1 버전에서 제2 버전으로의 소프트웨어 업데이트가 완료되면, 제1 데이터에 포함된 델타 파일로 제1 버전의 소프트웨어에 포함된 일부 파일이 대체될 수 있다. 따라서, 소프트웨어의 업데이트가 완료된 후 제2 버전의 소프트웨어의 크기는 제1 버전의 소프트웨어의 크기와 동일할 수 있다. 예를 들어, 제1 버전의 소프트웨어의 크기가 1GB인 경우, 200MB의 크기를 갖는 델타 파일로 제1 버전의 소프트웨어에 포함된 200MB의 크기를 갖는 일부 파일이 대체됨에 따라, 제2 버전의 소프트웨어의 크기는 1GB가 될 수 있다. 즉, 소프트웨어 업데이트가 완료되면 다시 제1 데이터의 크기만큼의 메모리(20) 공간이 확보되기 때문에, 프로세서(30)는 제1 서버(200)로부터 제2 데이터를 수신함으로써 제2 데이터를 복원할 수 있다.
한편, 이상에서는 소프트웨어의 업데이트가 완료된 후 제2 버전의 소프트웨어의 크기는 제1 버전의 소프트웨어의 크기와 동일한 경우를 전제로 설명하였으나, 소프트웨어 업데이트의 방식에 따라서는 제2 버전의 소프트웨어의 크기는 제1 버전의 소프트웨어의 크기보다 클 수도 있다. 이 경우, 프로세서(30)는 메모리(20)의 공간을 확보함에 있어서, 제2 버전의 소프트웨어의 크기와 제1 버전의 소프트웨어의 크기 사이의 차이만큼의 용량을 더 확보할 수 있도록 제2 데이터의 크기를 결정할 수 있다.
한편, 전술한 바와 같이 제2 데이터가 암호화된 제3 데이터를 제1 서버(200)로 전송한 경우, 소프트웨어의 업데이트가 완료되면, 프로세서(30)는 통신 모듈(10)을 통해 제1 서버(200)로부터 제3 데이터를 수신하고, 수신된 제3 데이터를 복호화하여 제2 데이터를 획득하며, 획득된 제2 데이터를 메모리(20)에 저장함으로써, 제2 데이터를 복원할 수도 있다.
한편, 이상에서는 식별된 제2 데이터를 제1 서버(200)에 백업하는 실시 예에 대해 설명하였으나, 본 개시가 이에 국한되는 것은 아니다. 예를 들어, 전자 장치(100)의 메모리(20)는 전자 장치(100)의 제조 시에 장착된 "내부 저장소" 및 사용자에 의해 추가적으로 장착된 "외부 저장소(예: SD 카드(Secure Digital Card))"를 포함할 수 있다. 이 경우, 프로세서(30)는 전자 장치(100)의 "내부 저장소"의 잔여 용량이 제1 데이터의 크기 미만이면, "내부 저장소"에서 제1 데이터의 크기에 대응되는 크기를 가지는 제2 데이터를 식별하고, 식별된 제2 데이터를 "외부 저장소"에 백업할 수도 있다. 또 다른 예로서, 프로세서(30)는 식별된 제2 데이터를 전자 장치(100)(예: 스마트 폰)에 연결된 외부 장치(예: PC)에 백업할 수도 있다.
도 1을 참조하여 상술한 실시 예에 따르면, 전자 장치(100)는 전자 장치(100)에 소프트웨어의 업데이트를 위해 필요한 데이터를 저장할 수 있는 공간이 확보되어 있지 않은 경우에도, 효율적이고도 신뢰할 수 있는 방법으로 소프트웨어의 업데이트를 원활하게 수행할 수 있게 된다.
도 2는 본 개시의 일 실시 예에 따른 소프트웨어 모듈들을 상세하게 나타내는 도면이고, 도 3은 본 개시의 일 실시 예에 따른 전자 장치(100), 제1 서버(200) 및 제2 서버(300)의 동작을 구체적으로 나타내는 시퀀스도이다. 이하에서는 도 2 및 도 3을 함께 참조하여 본 개시의 다양한 실시 예에 대해 설명한다.
도 2에 도시된 바와 같이, 본 개시에 따른 소프트웨어 모듈은 업데이트 관리 모듈(31)(update management module), 분석 모듈(33)(analysis module), 백업 모듈(33)(backup module), 삭제 모듈(39)(deletion module) 및 복원 모듈(37)(restoration module)을 포함할 수 있다.
'업데이트 관리 모듈(31)'은 본 개시에 따른 소프트웨어 업데이트의 전체 과정을 관장할 수 있도록 구성된 모듈을 말한다. 즉, 업데이트 관리 모듈(31)은 소프트웨어를 업데이트하기 위한 요청의 수신 여부를 식별하고, 후술하는 바와 같은 다른 모듈들을 호출함으로써 다른 모듈들의 동작을 전반적으로 제어할 수 있다.
구체적으로, 업데이트 관리 모듈(31)은 소프트웨어의 업데이트 필요 여부에 대한 확인 요청을 제2 서버(300)로 전송하도록 통신 모듈(10)을 제어할 수 있다(S310). 그리고, 소프트웨어의 업데이트가 필요한 경우이면, 업데이트 관리 모듈(31)은 통신 모듈(10)을 통해 제2 서버(300)로부터 확인 요청에 대한 응답을 수신할 수 있다(S315). 한편, 도 3에 도시된 바와 같이, 확인 요청에 대한 응답에는 제1 데이터의 크기에 대한 정보가 포함될 수 있다.
'분석 모듈(33)'은 소프트웨어를 업데이트하기 위한 메모리(20)의 공간을 확보하기 위한 분석 과정을 수행할 수 있도록 구성된 모듈을 말한다. 구체적으로, 업데이트 관리 모듈(31)로부터 메모리(20)의 잔여 용량 분석 및 제2 데이터 식별을 위한 요청이 수신되면, 분석 모듈(33)은 메모리(20)의 잔여 용량을 식별할 수 있다(S320). 식별 결과 메모리(20)의 잔여 용량이 식별된 제1 데이터의 크기 미만이면, 분석 모듈(33)은 메모리(20)에서 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버(200)에 백업될 제2 데이터를 식별할 수 있다(S325). 그리고, 제2 데이터가 식별되면, 분석 모듈(33)은 제2 데이터에 포함된 적어도 하나의 파일의 리스트에 대한 정보를 백업 모듈(33)로 전송할 수 있다.
'백업 모듈(33)'은 제2 데이터를 제1 서버(200)에 백업할 수 있도록 구성된 모듈을 말하며, 업로드 모듈(upload module)로 지칭될 수도 있다. 구체적으로, 분석 모듈(33)로부터 제2 데이터에 포함된 적어도 하나의 파일의 리스트에 대한 정보가 수신되면, 백업 모듈(33)은 제2 데이터에 포함된 적어도 하나의 파일을 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어할 수 있다(S330). 그리고, 백업 모듈(33)은 통신 모듈(10)을 통해 제1 서버(200)로부터 제2 데이터에 포함된 적어도 하나의 파일에 대한 업로드가 완료되었음을 나타내는 정보를 수신할 수 있다(S335).
제1 서버(200)로부터 적어도 하나의 파일에 대한 업로드가 완료되었음을 나타내는 정보가 수신되면, 백업 모듈(33)은 제2 데이터에 포함된 적어도 하나의 파일의 삭제를 위한 요청을 삭제 모듈(39)로 전송할 수 있다. 한편, 백업 모듈(33)은 제2 데이터에 포함된 적어도 하나의 파일을 제1 서버(200)에 전송하는 것에 관련된 정보를 사용자에게 제공할 수도 있다. 여기서, 적어도 하나의 파일을 제1 서버(200)에 전송하는 것에 관련된 정보는 적어도 하나의 파일을 제1 서버(200)에 전송하는 과정에서 사용되는 무선 네트워크 데이터의 사용량 및 적어도 하나의 파일이 사용자의 프라이버시에 관련된 정보를 포함할 수 있다는 것을 나타내는 정보 등을 포함할 수 있다. 적어도 하나의 파일을 제1 서버(200)에 전송하는 것에 관련된 정보를 제공하기 위한 사용자 인터페이스에 대해서는 도 5 내지 도 7을 참조하여 보다 구체적으로 설명한다.
'삭제 모듈(39)'은 제2 데이터의 업로드가 완료된 후 메모리(20)에서 제2 데이터를 삭제할 수 있도록 구성된 모듈을 말한다. 구체적으로, 백업 모듈(33)로부터 제2 데이터에 포함된 적어도 하나의 파일의 삭제를 위한 요청이 수신되면, 삭제 모듈(39)은 메모리(20)에서 제2 데이터에 포함된 적어도 하나의 파일을 삭제하고(S340), 제2 데이터에 포함된 적어도 하나의 파일의 리스트에 대한 정보 및 제2 데이터에 포함된 적어도 하나의 파일이 삭제되었음을 나타내는 정보를 업데이트 관리 모듈(31)로 전송할 수 있다.
이에 따라, 업데이트 관리 모듈(31)은 제1 데이터에 대한 전송 요청을 제2 서버(300)로 전송하도록 통신 모듈(10)을 제어하고(S345), 이에 따라 통신 모듈(10)을 통해 제2 서버(300)로부터 제1 데이터를 수신할 수 있다(S350). 그리고, 업데이트 관리 모듈(31)은 제1 데이터를 바탕으로 소프트웨어 업데이트를 수행할 수 있다(S355). 그 후, 업데이트 관리 모듈(31)은 제2 데이터에 포함된 적어도 하나의 파일의 리스트에 대한 정보를 복원 모듈(37)로 전송할 수 있다.
'복원 모듈(37)'은 소프트웨어의 업데이트가 완료된 후 제1 서버(200)로부터 제2 데이터를 복원할 수 있도록 구성된 모듈을 말한다. 구체적으로, 업데이트 관리 모듈(31)로부터 제2 데이터에 포함된 적어도 하나의 파일의 리스트에 대한 정보가 수신되면, 복원 모듈(37)은 제2 데이터에 대한 전송 요청을 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어하고(S360), 이에 따라 통신 모듈(10)을 통해 제1 서버(200)로부터 제2 데이터를 수신할 수 있다(S365). 그 후, 복원 모듈(37)은 제2 데이터에 포함된 적어도 하나의 파일을 메모리(20)에 저장함으로써 제2 데이터에 포함된 적어도 하나의 파일을 복원할 수 있다(S370). 제2 데이터에 대한 복원이 완료되면, 복원 모듈(37)은 업데이트 관리 모듈(31)로 제2 데이터에 대한 복원이 완료되었음을 나타내는 정보를 전송할 수 있으며, 이에 따라 본 개시에 따른 소프트웨어 업데이트의 과정이 완결될 수 있다.
한편, 복원 모듈(37)은 제2 데이터에 포함된 적어도 하나의 파일에 대한 정보를 제1 서버(200)로 전송함으로써 제2 데이터의 전송을 요청할 수도 있으나, 제1 서버(200)에서 사용자를 위해 할당된 디렉토리의 데이터를 전부 전송해 줄 것을 요청함으로써 제2 데이터의 복원에 대한 무결성을 보장할 수도 있다.
도 4는 본 개시에 따른 전자 장치(100)의 하드웨어 구성을 상세하게 나타내는 도면이다.
구체적으로, 도 4는 다양한 실시 예들에 따른 네트워크 환경(1000) 내의 전자 장치(100)의 블록도이다. 도 4를 참조하면, 네트워크 환경(1000)에서 전자 장치(100)는 제 1 네트워크(98)(예: 근거리 무선 통신 네트워크)를 통하여 외부 장치(400)와 통신하거나, 또는 제 2 네트워크(99)(예: 원거리 무선 통신 네트워크)를 통하여 제1 서버(200) 또는 제2 서버(300) 중 적어도 하나와 통신할 수 있다.
일 실시 예에 따르면, 전자 장치(100)는 제2 서버(300)를 통하여 제1 서버(200)와 통신할 수 있다. 일 실시 예에 따르면, 전자 장치(100)는 프로세서(30), 메모리(20), 입력 모듈(40), 음향 출력 모듈(60), 디스플레이 모듈(50), 오디오 모듈(70), 센서 모듈(76), 인터페이스(77), 연결 단자(78), 햅틱 모듈(79), 카메라 모듈(80), 전력 관리 모듈(88), 배터리(89), 통신 모듈(10), 가입자 식별 모듈(96), 또는 안테나 모듈(97)을 포함할 수 있다. 어떤 실시 예에서는, 전자 장치(100)에는, 이 구성요소들 중 적어도 하나(예: 연결 단자(78))가 생략되거나, 하나 이상의 다른 구성요소가 추가될 수 있다. 어떤 실시 예에서는, 이 구성요소들 중 일부들(예: 센서 모듈(76), 카메라 모듈(80), 또는 안테나 모듈(97))은 하나의 구성요소(예: 디스플레이 모듈(50))로 통합될 수 있다.
통신 모듈(10)은 전자 장치(100)와 외부 장치(400), 제1 서버(200), 또는 제2 서버(300)) 간의 직접(예: 유선) 통신 채널 또는 무선 통신 채널의 수립, 및 수립된 통신 채널을 통한 통신 수행을 지원할 수 있다. 통신 모듈(10)은 프로세서(30)(예: 어플리케이션 프로세서)와 독립적으로 운영되고, 직접(예: 유선) 통신 또는 무선 통신을 지원하는 하나 이상의 커뮤니케이션 프로세서를 포함할 수 있다.
일 실시 예에 따르면, 통신 모듈(10)은 무선 통신 모듈(12)(예: 셀룰러 통신 모듈, 근거리 무선 통신 모듈, 또는 GNSS(global navigation satellite system) 통신 모듈) 또는 유선 통신 모듈(14)(예: LAN(local area network) 통신 모듈, 또는 전력선 통신 모듈)을 포함할 수 있다. 이들 통신 모듈 중 해당하는 통신 모듈은 제 1 네트워크(98)(예: 블루투스, WiFi(wireless fidelity) direct 또는 IrDA(infrared data association)와 같은 근거리 통신 네트워크) 또는 제 2 네트워크(99)(예: 레거시 셀룰러 네트워크, 5G 네트워크, 차세대 통신 네트워크, 인터넷, 또는 컴퓨터 네트워크(예: LAN 또는 WAN)와 같은 원거리 통신 네트워크)를 통하여 외부의 장치(예: 제1 서버(100)와 통신할 수 있다. 이런 여러 종류의 통신 모듈들은 하나의 구성요소(예: 단일 칩)로 통합되거나, 또는 서로 별도의 복수의 구성요소들(예: 복수 칩들)로 구현될 수 있다. 무선 통신 모듈(12)은 가입자 식별 모듈(96)에 저장된 가입자 정보(예: 국제 모바일 가입자 식별자(IMSI))를 이용하여 제 1 네트워크(98) 또는 제 2 네트워크(99)와 같은 통신 네트워크 내에서 전자 장치(100)를 확인 또는 인증할 수 있다.
무선 통신 모듈(12)은 4G 네트워크 이후의 5G 네트워크 및 차세대 통신 기술, 예를 들어, NR 접속 기술(new radio access technology)을 지원할 수 있다. NR 접속 기술은 고용량 데이터의 고속 전송(eMBB(enhanced mobile broadband)), 단말 전력 최소화와 다수 단말의 접속(mMTC(massive machine type communications)), 또는 고신뢰도와 저지연(URLLC(ultra-reliable and low-latency communications))을 지원할 수 있다. 무선 통신 모듈(12)은, 예를 들어, 높은 데이터 전송률 달성을 위해, 고주파 대역(예: mmWave 대역)을 지원할 수 있다. 무선 통신 모듈(12)은 고주파 대역에서의 성능 확보를 위한 다양한 기술들, 예를 들어, 빔포밍(beamforming), 거대 배열 다중 입출력(massive MIMO(multiple-input and multiple-output)), 전차원 다중입출력(FD-MIMO: full dimensional MIMO), 어레이 안테나(array antenna), 아날로그 빔형성(analog beam-forming), 또는 대규모 안테나(large scale antenna)와 같은 기술들을 지원할 수 있다. 무선 통신 모듈(12)은 전자 장치(100), 외부의 장치(예: 제1 서버(200)) 또는 네트워크 시스템(예: 제 2 네트워크(99))에 규정되는 다양한 요구사항을 지원할 수 있다. 일 실시 예에 따르면, 무선 통신 모듈(12)은 eMBB 실현을 위한 Peak data rate(예: 20Gbps 이상), mMTC 실현을 위한 손실 Coverage(예: 164dB 이하), 또는 URLLC 실현을 위한 U-plane latency(예: 다운링크(DL) 및 업링크(UL) 각각 0.5ms 이하, 또는 라운드 트립 1ms 이하)를 지원할 수 있다.
메모리(20)는 전자 장치(100)의 적어도 하나의 구성요소(예: 프로세서(30) 또는 센서 모듈(76))에 의해 사용되는 다양한 데이터를 저장할 수 있다. 데이터는, 예를 들어, 소프트웨어(예: 소프트웨어(90)) 및 이와 관련된 명령에 대한 입력 데이터 또는 출력 데이터를 포함할 수 있다. 메모리(20)는, 휘발성 메모리(22) 또는 비휘발성 메모리(24)를 포함할 수 있다.
소프트웨어(90)은 메모리(20)에 소프트웨어로서 저장될 수 있으며, 예를 들면, 어플리케이션(91), 미들 웨어(93) 또는 운영 체제(95)를 포함할 수 있다. 본 개시에 있어서, '소프트웨어'는 '프로그램'이라는 용어로 대체될 수 있다.
프로세서(30)는 예를 들면, 소프트웨어(예: 소프트웨어(90))를 실행하여 프로세서(30)에 연결된 전자 장치(100)의 적어도 하나의 다른 구성요소(예: 하드웨어 또는 소프트웨어 구성요소)를 제어할 수 있고, 다양한 데이터 처리 또는 연산을 수행할 수 있다.
일 실시 예에 따르면, 데이터 처리 또는 연산의 적어도 일부로서, 프로세서(30)는 다른 구성요소(예: 센서 모듈(76) 또는 통신 모듈(10))로부터 수신된 명령 또는 데이터를 휘발성 메모리(22)에 저장하고, 휘발성 메모리(22)에 저장된 명령 또는 데이터를 처리하고, 결과 데이터를 비휘발성 메모리(24)에 저장할 수 있다. 일 실시 예에 따르면, 프로세서(30)는 메인 프로세서(32)(예: 중앙 처리 장치 또는 어플리케이션 프로세서) 또는 이와는 독립적으로 또는 함께 운영 가능한 보조 프로세서(34)(예: 그래픽 처리 장치, 신경망 처리 장치(NPU: neural processing unit), 이미지 시그널 프로세서, 센서 허브 프로세서, 또는 커뮤니케이션 프로세서)를 포함할 수 있다. 예를 들어, 전자 장치(100)가 메인 프로세서(32) 및 보조 프로세서(34)를 포함하는 경우, 보조 프로세서(34)는 메인 프로세서(32)보다 저전력을 사용하거나, 지정된 기능에 특화되도록 설정될 수 있다. 보조 프로세서(34)는 메인 프로세서(32)와 별개로, 또는 그 일부로서 구현될 수 있다.
보조 프로세서(34)는 예를 들면, 메인 프로세서(32)가 인액티브(예: 슬립) 상태에 있는 동안 메인 프로세서(32)를 대신하여, 또는 메인 프로세서(32)가 액티브(예: 어플리케이션 실행) 상태에 있는 동안 메인 프로세서(32)와 함께, 전자 장치(100)의 구성요소들 중 적어도 하나의 구성요소(예: 디스플레이 모듈(50), 센서 모듈(76), 또는 통신 모듈(10))와 관련된 기능 또는 상태들의 적어도 일부를 제어할 수 있다. 일 실시 예에 따르면, 보조 프로세서(34)(예: 이미지 시그널 프로세서 또는 커뮤니케이션 프로세서)는 기능적으로 관련 있는 다른 구성요소(예: 카메라 모듈(80) 또는 통신 모듈(10))의 일부로서 구현될 수 있다.
일 실시 예에 따르면, 보조 프로세서(34)(예: 신경망 처리 장치)는 인공지능 모델의 처리에 특화된 하드웨어 구조를 포함할 수 있다. 인공지능 모델은 기계 학습을 통해 생성될 수 있다. 이러한 학습은, 예를 들어, 인공지능 모델이 수행되는 전자 장치(100) 자체에서 수행될 수 있고, 별도의 서버를 통해 수행될 수도 있다. 학습 알고리즘은, 예를 들어, 지도형 학습(supervised learning), 비지도형 학습(unsupervised learning), 준지도형 학습(semi-supervised learning) 또는 강화 학습(reinforcement learning)을 포함할 수 있으나, 전술한 예에 한정되지 않는다. 인공지능 모델은, 복수의 인공 신경망 레이어들을 포함할 수 있다. 인공 신경망은 심층 신경망(DNN: deep neural network), CNN(convolutional neural network), RNN(recurrent neural network), RBM(restricted boltzmann machine), DBN(deep belief network), BRDNN(bidirectional recurrent deep neural network), 심층 Q-네트워크(deep Q-networks) 또는 상기 중 둘 이상의 조합 중 하나일 수 있으나, 전술한 예에 한정되지 않는다. 인공지능 모델은 하드웨어 구조 이외에, 추가적으로 또는 대체적으로, 소프트웨어 구조를 포함할 수 있다.
입력 모듈(40)은 전자 장치(100)의 구성요소(예: 프로세서(30))에 사용될 명령 또는 데이터를 전자 장치(100)의 외부(예: 사용자)로부터 수신할 수 있다. 입력 모듈(40)은, 예를 들면, 마이크, 마우스, 키보드, 키(예: 버튼), 또는 디지털 펜(예: 스타일러스 펜)을 포함할 수 있다.
음향 출력 모듈(60)은 음향 신호를 전자 장치(100)의 외부로 출력할 수 있다. 음향 출력 모듈(60)은, 예를 들면, 스피커 또는 리시버를 포함할 수 있다. 스피커는 멀티미디어 재생 또는 녹음 재생과 같이 일반적인 용도로 사용될 수 있다. 리시버는 착신 전화를 수신하기 위해 사용될 수 있다. 일 실시 예에 따르면, 리시버는 스피커와 별개로, 또는 그 일부로서 구현될 수 있다.
디스플레이 모듈(50)은 전자 장치(100)의 외부(예: 사용자)로 정보를 시각적으로 제공할 수 있다. 디스플레이 모듈(50)은, 예를 들면, 디스플레이, 홀로그램 장치, 또는 프로젝터 및 해당 장치를 제어하기 위한 제어 회로를 포함할 수 있다. 일 실시 예에 따르면, 디스플레이 모듈(50)은 터치를 감지하도록 설정된 터치 센서, 또는 상기 터치에 의해 발생되는 힘의 세기를 측정하도록 설정된 압력 센서를 포함할 수 있다. 특히, 디스플레이 모듈(50)을 통해 제공되는 사용자 인터페이스(user interface, UI)에 대해서는 도 5 내지 도 7을 참조하여 상세하게 설명한다.
오디오 모듈(70)은 소리를 전기 신호로 변환시키거나, 반대로 전기 신호를 소리로 변환시킬 수 있다. 일 실시 예에 따르면, 오디오 모듈(70)은, 입력 모듈(40)을 통해 소리를 획득하거나, 음향 출력 모듈(60), 또는 전자 장치(100)와 직접 또는 무선으로 연결된 외부의 장치(예: 외부 장치(400))(예: 스피커 또는 헤드폰)를 통해 소리를 출력할 수 있다.
센서 모듈(76)은 전자 장치(100)의 작동 상태(예: 전력 또는 온도), 또는 외부의 환경 상태(예: 사용자 상태)를 감지하고, 감지된 상태에 대응하는 전기 신호 또는 데이터 값을 생성할 수 있다. 일 실시 예에 따르면, 센서 모듈(76)은, 예를 들면, 제스처 센서, 자이로 센서, 기압 센서, 마그네틱 센서, 가속도 센서, 그립 센서, 근접 센서, 컬러 센서, IR(infrared) 센서, 생체 센서, 온도 센서, 습도 센서, 또는 조도 센서를 포함할 수 있다.
인터페이스(77)는 전자 장치(100)가 외부의 장치(예: 외부 장치(400))와 직접 또는 무선으로 연결되기 위해 사용될 수 있는 하나 이상의 지정된 프로토콜들을 지원할 수 있다. 일 실시 예에 따르면, 인터페이스(77)는, 예를 들면, HDMI(high definition multimedia interface), USB(universal serial bus) 인터페이스, SD카드 인터페이스, 또는 오디오 인터페이스를 포함할 수 있다.
연결 단자(78)는 그를 통해서 전자 장치(100)가 외부의 장치(예: 외부 장치(400))와 물리적으로 연결될 수 있는 커넥터를 포함할 수 있다. 일 실시 예에 따르면, 연결 단자(78)는, 예를 들면, HDMI 커넥터, USB 커넥터, SD 카드 커넥터, 또는 오디오 커넥터(예: 헤드폰 커넥터)를 포함할 수 있다.
햅틱 모듈(79)은 전기적 신호를 사용자가 촉각 또는 운동 감각을 통해서 인지할 수 있는 기계적인 자극(예: 진동 또는 움직임) 또는 전기적인 자극으로 변환할 수 있다. 일 실시 예에 따르면, 햅틱 모듈(79)은, 예를 들면, 모터, 압전 소자, 또는 전기 자극 장치를 포함할 수 있다.
카메라 모듈(80)은 정지 영상 및 동영상을 촬영할 수 있다. 일 실시 예에 따르면, 카메라 모듈(80)은 하나 이상의 렌즈들, 이미지 센서들, 이미지 시그널 프로세서들, 또는 플래시들을 포함할 수 있다.
전력 관리 모듈(88)은 전자 장치(100)에 공급되는 전력을 관리할 수 있다. 일 실시 예에 따르면, 전력 관리 모듈(88)은, 예를 들면, PMIC(power management integrated circuit)의 적어도 일부로서 구현될 수 있다.
배터리(89)는 전자 장치(100)의 적어도 하나의 구성요소에 전력을 공급할 수 있다. 일 실시 예에 따르면, 배터리(89)는, 예를 들면, 재충전 불가능한 1차 전지, 재충전 가능한 2차 전지 또는 연료 전지를 포함할 수 있다.
안테나 모듈(97)은 신호 또는 전력을 외부(예: 외부의 전자 장치)로 송신하거나 외부로부터 수신할 수 있다. 일 실시 예에 따르면, 안테나 모듈(97)은 서브스트레이트(예: PCB) 위에 형성된 도전체 또는 도전성 패턴으로 이루어진 방사체를 포함하는 안테나를 포함할 수 있다. 일 실시 예에 따르면, 안테나 모듈(97)은 복수의 안테나들(예: 어레이 안테나)을 포함할 수 있다. 이런 경우, 제 1 네트워크(98) 또는 제 2 네트워크(99)와 같은 통신 네트워크에서 사용되는 통신 방식에 적합한 적어도 하나의 안테나가, 예를 들면, 통신 모듈(10)에 의하여 상기 복수의 안테나들로부터 선택될 수 있다. 신호 또는 전력은 상기 선택된 적어도 하나의 안테나를 통하여 통신 모듈(10)과 외부의 전자 장치 간에 송신되거나 수신될 수 있다. 어떤 실시 예에 따르면, 방사체 이외에 다른 부품(예: RFIC(radio frequency integrated circuit))이 추가로 안테나 모듈(97)의 일부로 형성될 수 있다.
다양한 실시 예에 따르면, 안테나 모듈(97)은 mmWave 안테나 모듈을 형성할 수 있다. 일 실시 예에 따르면, mmWave 안테나 모듈은 인쇄 회로 기판, 상기 인쇄 회로 기판의 제 1 면(예: 아래 면)에 또는 그에 인접하여 배치되고 지정된 고주파 대역(예: mmWave 대역)을 지원할 수 있는 RFIC, 및 상기 인쇄 회로 기판의 제 2 면(예: 윗 면 또는 측 면)에 또는 그에 인접하여 배치되고 상기 지정된 고주파 대역의 신호를 송신 또는 수신할 수 있는 복수의 안테나들(예: 어레이 안테나)을 포함할 수 있다.
상기 구성요소들 중 적어도 일부는 주변 기기들간 통신 방식(예: 버스, GPIO(general purpose input and output), SPI(serial peripheral interface), 또는 MIPI(mobile industry processor interface))을 통해 서로 연결되고 신호(예: 명령 또는 데이터)를 상호간에 교환할 수 있다.
일 실시 예에 따르면, 명령 또는 데이터는 제 2 네트워크(99)에 연결된 제2 서버(300)를 통해서 전자 장치(100)와 외부의 제1 서버(200)간에 송신 또는 수신될 수 있다. 외부의 전자 장치(400, 또는 200) 각각은 전자 장치(100)와 동일한 또는 다른 종류의 장치일 수 있다. 일 실시 예에 따르면, 전자 장치(100)에서 실행되는 동작들의 전부 또는 일부는 외부의 전자 장치들(400, 200, 또는 300) 중 하나 이상의 외부의 전자 장치들에서 실행될 수 있다. 예를 들면, 전자 장치(100)가 어떤 기능이나 서비스를 자동으로, 또는 사용자 또는 다른 장치로부터의 요청에 반응하여 수행해야 할 경우에, 전자 장치(100)는 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 하나 이상의 외부의 전자 장치들에게 그 기능 또는 그 서비스의 적어도 일부를 수행하라고 요청할 수 있다. 상기 요청을 수신한 하나 이상의 외부의 전자 장치들은 요청된 기능 또는 서비스의 적어도 일부, 또는 상기 요청과 관련된 추가 기능 또는 서비스를 실행하고, 그 실행의 결과를 전자 장치(100)로 전달할 수 있다. 전자 장치(100)는 상기 결과를, 그대로 또는 추가적으로 처리하여, 상기 요청에 대한 응답의 적어도 일부로서 제공할 수 있다.
이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 모바일 에지 컴퓨팅(MEC: mobile edge computing), 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다. 전자 장치(100)는, 예를 들어, 분산 컴퓨팅 또는 모바일 에지 컴퓨팅을 이용하여 초저지연 서비스를 제공할 수 있다. 다른 실시 예에 있어서, 제1 서버(200)는 IoT(internet of things) 기기를 포함할 수 있다. 제2 서버(300)는 기계 학습 및/또는 신경망을 이용한 지능형 서버일 수 있다. 일 실시 예에 따르면, 외부의 제1 서버(200) 또는 제2 서버(300)는 제 2 네트워크(99) 내에 포함될 수 있다. 전자 장치(100)는 5G 통신 기술 및 IoT 관련 기술을 기반으로 지능형 서비스(예: 스마트 홈, 스마트 시티, 스마트 카, 또는 헬스 케어)에 적용될 수 있다.
도 5는 본 개시의 일 실시 예에 따른 제1 사용자 인터페이스(510)의 일 예를 나타내는 도면이다.
일 실시 예에 있어서, 프로세서(30)는 메모리(20)의 잔여 용량이 식별된 크기 미만이면, 메모리(20)에 저장된 복수의 파일 중 적어도 일부 파일에 대한 리스트를 포함하는 제1 사용자 인터페이스(510)를 표시하도록 디스플레이 모듈을 제어할 수 있다. 그리고, 프로세서(30)는 제1 사용자 인터페이스(510)를 통해 리스트에 포함된 파일들 중 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력을 수신하고, 제2 사용자 입력을 바탕으로 제2 데이터를 식별할 수 있다.
도 5의 예를 참조하면, 제1 사용자 인터페이스(510)에 포함된 리스트는 복수의 이미지 파일의 명칭과 크기를 나타내는 정보 및 복수의 대용량 파일의 명칭과 크기를 나타내는 정보를 포함할 수 있다. 여기서, 복수의 이미지 파일 및 복수의 대용량 파일은 전술한 바와 같은 복수의 결정 기준 중 파일의 형식 및 파일의 크기를 바탕으로 식별된 파일들일 수 있다.
한편, 제1 사용자 인터페이스(510)는 "정렬"이라는 UI 아이템(513)을 더 포함할 수 있다. "정렬"이라는 UI 아이템(513)을 선택하는 사용자의 터치 입력이 수신되면, 프로세서(30)는 리스트에 포함된 복수의 이미지 파일 및 복수의 대용량 파일을 전술한 바와 같은 복수의 결정 기준 중 적어도 하나에 따라 정렬하여 표시할 수 있다.
한편, 제1 사용자 인터페이스(510)는 리스트에 포함된 파일들 각각에 대응되는 체크 박스 형태의 UI 아이템들을 포함할 수 있다(예: 이미지 파일 "20200917_1645.jpg"에 대응되는 체크 박스 형태의 UI 아이템(511)). 그리고, 제2 데이터에 포함될 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력은 도 5의 리스트에 포함된 파일들 각각에 대응되는 체크 박스 형태의 UI 아이템들 중 적어도 하나의 아이템을 선택한 후 "업로드"라는 UI 아이템(512)을 선택하는 사용자의 터치 인터렉션을 바탕으로 입력될 수 있다.
도 6a 및 도 6b는 본 개시의 일 실시 예에 따른 제2 사용자 인터페이스(610, 620)의 일 예를 나타내는 도면이다.
일 실시 예에 있어서, 프로세서(30)는 제2 데이터가 식별되면, 잔여 용량이 식별된 크기 미만이라는 정보를 포함하는 제2 사용자 인터페이스(610, 620)를 표시하도록 디스플레이 모듈을 제어할 수 있다. 그리고, 제2 사용자 인터페이스(610, 620)를 통해 제2 데이터를 제1 서버(200)로 전송하기 위한 제3 사용자 입력이 수신되면, 프로세서(30)는 제2 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어할 수 있다.
도 6a의 예를 참조하면, 제2 사용자 인터페이스(610, 620)는 현재 디바이스의 잔여 용량이 부족하다는 점을 나타내는 정보 및 제2 데이터를 제1 서버(200)로 전송할 것인지 여부에 대한 사용자의 선택을 요청하기 위한 정보를 포함할 수 있다. 그리고, 제2 사용자 인터페이스(610, 620)는 "네"라는 UI 아이템 및 "아니오"라는 UI 아이템을 포함할 수 있다. "네"라는 UI 아이템 및 "아니오"라는 UI 아이템 중 "네"라는 UI 아이템이 선택되면, 프로세서(30)는 제2 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어할 수 있다.
도 6b의 예를 참조하면, 제2 사용자 인터페이스(610, 620)는 현재 디바이스의 잔여 용량이 부족하다는 점을 나타내는 정보 및 제2 데이터를 제1 서버(200)로 전송할 것인지 여부에 대한 사용자의 확인을 요청하기 위한 정보를 포함할 수 있다. 그리고, 제2 사용자 인터페이스(610, 620)는 "확인"이라는 UI 아이템을 포함할 수 있다. 그리고, 제3 사용자 입력은 "확인"이라는 UI 아이템을 선택하는 사용자의 터치 인터렉션을 바탕으로 입력될 수 있다.
도 7은 본 개시의 일 실시 예에 따른 제3 사용자 인터페이스(710)의 일 예를 나타내는 도면이다.
일 실시 예에 있어서, 프로세서(30)는 복수의 결정 기준에 대한 리스트를 포함하는 제3 사용자 인터페이스(710)를 표시하도록 디스플레이 모듈을 제어할 수 있다. 그리고, 제3 사용자 인터페이스(710)를 통해 복수의 결정 기준 중 적어도 하나의 결정 기준을 선택하는 제4 사용자 입력이 수신되면, 프로세서(30)는 적어도 하나의 결정 기준을 바탕으로 메모리(20)에 저장된 복수의 파일 중 적어도 하나의 파일을 식별할 수 있다.
도 7의 예를 참조하면, 제3 사용자 인터페이스(710)는 복수의 결정 기준에 대한 사용자의 선택을 요청하기 위한 정보를 포함할 수 있다. 그리고, 제3 사용자 인터페이스(710)는 복수의 결정 기준 각각에 대응되는 체크 박스 형태의 UI 아이템들을 포함할 수 있다. 제3 사용자 입력은 복수의 결정 기준 각각에 대응되는 체크 박스 형태의 UI 아이템들 중 적어도 하나를 선택하는 사용자의 터치 인터렉션을 바탕으로 입력될 수 있다.
도 7에서, 체크되지 않은 형태의 UI 아이템(711)은 사용자에 의해 선택되지 않은 결정 기준을 나타내며, 체크된 형태의 UI 아이템(712)은 사용자에 의해 선택된 결정 기준을 나타낸다.
한편, 도시하지는 않았으나, 프로세서(30)는 제2 데이터를 제1 서버(200)로 전송함에 있어서 소요되는 데이터 사용량에 대한 정보를 포함하는 사용자 인터페이스를 제공할 수도 있으며, 이에 따라 사용자는 WiFi 네트워크를 이용하여 제2 데이터를 제1 서버(200)로 업로드할 수 있게 된다.
이상에서 도 5 내지 도 7을 참조하여 상술한 바에 따르면, 제2 데이터에 포함되는 적어도 하나의 파일은 프로세서(30)에 의해 자동으로 식별되어 제1 서버(200)로 전송될 수 있을 뿐만 아니라, 사용자에 의해 직접 선택될 수도 있으며, 사용자의 확인 후에 제1 서버(200)로 전송될 수도 있고, 사용자에 의해 선택된 결정 기준에 맞게 프로세서(30)에 의해 식별될 수도 있다. 이에 따라, 본 개시에 따른 제2 데이터의 백업 과정에 대한 사용자의 신뢰성과 편의성이 현저하게 향상될 수 있다.
도 8은 본 개시의 일 실시 예에 따른 전자 장치(100)의 제어 방법을 나타내는 흐름도이다.
도 8에 도시된 바와 같이, 소프트웨어를 업데이트하기 위한 요청이 수신되면(S810-Y), 전자 장치(100)는 업데이트를 위해 필요한 제1 데이터의 크기를 식별할 수 있으며(S815), 제1 데이터의 크기와 메모리(20)의 잔여 용량을 비교할 수 있다.
구체적으로, 전자 장치(100)는 제2 서버(300)로부터 수신된 제1 데이터의 크기에 대한 정보를 바탕으로 제1 데이터의 크기를 식별하고, 제1 데이터의 크기와 메모리(20)의 잔여 용량을 비교함으로써, 소프트웨어를 업데이트하기 위한 메모리(20)의 공간이 확보되었는지 여부를 식별할 수 있다.
메모리(20)의 잔여 용량이 식별된 제1 데이터의 크기 이상이면(S820-N), 전자 장치(100)는 제1 데이터를 바탕으로 소프트웨어를 업데이트할 수 있다. 반면, 메모리(20)의 잔여 용량이 식별된 제1 데이터의 크기 미만이면(S820-Y), 전자 장치(100)는 메모리(20)에서 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버(200)에 백업될 제2 데이터를 식별할 수 있다(S825).
구체적으로, 전자 장치(100)는 기 정의된 복수의 결정 기준을 바탕으로 메모리(20)에 저장된 복수의 파일 중 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다. 보다 구체적으로, 전자 장치(100)는 복수의 파일 별로 복수의 결정 기준 각각에 대한 스코어를 획득하고 높은 스코어를 갖는 파일 순으로 제2 데이터에 포함시키는 방식으로, 제2 데이터에 포함되는 적어도 하나의 파일을 식별할 수 있다.
여기서, 복수의 결정 기준은 메모리(20)에서 복수의 파일이 저장된 위치, 복수의 파일의 크기, 복수의 파일이 메모리(20)에 저장된 시간, 복수의 파일의 형식, 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 복수의 파일의 중요도 중 적어도 하나를 포함할 수 있다. 복수의 결정 기준을 바탕으로 제2 데이터에 포함되는 적어도 하나의 파일을 식별하는 과정에 대해서는 도 1을 참조하여 상술하였으므로, 동일한 내용에 대한 중복 설명은 생략한다.
제2 데이터가 식별되면, 전자 장치(100)는 식별된 제2 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어하고(S830), 전송된 제2 데이터를 메모리(20)에서 삭제할 수 있다(S835). 다시 말해, 프로세서(30)는 제2 데이터에 포함된 적어도 하나의 파일을 제1 서버(200)로 업로드한 후 제2 데이터에 포함된 적어도 하나의 파일을 삭제함으로써, 제1 데이터를 다운로드할 수 있는 메모리(20)의 공간을 확보할 수 있다. 한편, 전자 장치(100)는 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하고, 제3 데이터를 제1 서버(200)로 전송하도록 통신 모듈(10)을 제어할 수도 있다.
제2 데이터가 메모리(20)에서 삭제되면, 전자 장치(100)는 통신 모듈(10)을 통해 제2 서버(300)로부터 제1 데이터를 수신하여 메모리(20)에 저장할 수 있다(S840). 그리고, 전자 장치(100)는 메모리(20)에 저장된 제1 데이터를 바탕으로 소프트웨어를 업데이트할 수 있다(S845). 다시 말해, 프로세서(30)는 제2 데이터를 삭제함으로써 확보된 메모리(20)의 공간에 제1 데이터를 다운로드한 후 제1 데이터를 바탕으로 소프트웨어를 업데이트할 수 있다.
소프트웨어의 업데이트가 완료되면(S850-Y), 전자 장치(100)는 통신 모듈(10)을 통해 제1 서버(200)로부터 제2 데이터를 수신하여 메모리(20)에 저장할 수 있다(S855). 다시 말해, 프로세서(30)는 소프트웨어의 업데이트가 완료된 후 제1 서버(200)에서 제2 데이터를 다운로드함으로써 제2 데이터를 복원할 수 있다.
한편, 상술한 실시 예에 따른 전자 장치(100)의 제어 방법은 프로그램으로 구현되어 전자 장치(100)에 제공될 수 있다. 특히, 전자 장치(100)의 제어 방법을 포함하는 프로그램은 비일시적 판독 가능 매체(non-transitory computer readable medium)에 저장되어 제공될 수 있다.
구체적으로, 전자 장치(100)의 제어 방법을 실행하는 프로그램을 포함하는 비일시적 컴퓨터 판독 가능 기록매체에 있어서, 전자 장치(100)의 제어 방법은 전자 장치(100)의 메모리(20)에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계, 메모리(20)의 잔여 용량이 식별된 제1 데이터의 크기 미만이면, 메모리(20)에서 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버(200)에 백업될 제2 데이터를 식별하는 단계, 식별된 제2 데이터를 제1 서버(200)로 전송하는 단계, 전송된 제2 데이터를 메모리(20)에서 삭제하는 단계, 제2 데이터가 메모리(20)에서 삭제되면, 제2 서버(300)로부터 제1 데이터를 수신하여 메모리(20)에 저장하는 단계, 메모리(20)에 저장된 제1 데이터를 바탕으로 소프트웨어를 업데이트하는 단계 및 소프트웨어의 업데이트가 완료되면, 제1 서버(200)로부터 제2 데이터를 수신하여 메모리(20)에 저장하는 단계를 포함한다.
이상에서 전자 장치(100)의 제어 방법, 그리고 전자 장치(100)의 제어 방법을 실행하는 프로그램을 포함하는 컴퓨터 판독 가능 기록매체에 대해 간략하게 설명하였으나, 이는 중복 설명을 생략하기 위한 것일 뿐이며, 도 1 내지 도 7을 참조하여 상술한 바와 같은 전자 장치(100)에 대한 다양한 실시 예는 전자 장치(100)의 제어 방법, 그리고 전자 장치(100)의 제어 방법을 실행하는 프로그램을 포함하는 컴퓨터 판독 가능 기록매체에 대해서도 적용될 수 있음은 물론이다.
한편, 본 개시에 따른 객체 인식 모듈을 비롯하여 본 개시를 구현함에 있어서 이용될 수 있는 신경망 모델 내지는 인공 지능 모델에 관련된 기능은 메모리(20) 및 프로세서(30)를 통해 수행될 수 있다.
프로세서(30)는 하나 또는 복수의 프로세서(30)로 구성될 수 있다. 이때, 하나 또는 복수의 프로세서(30)는 CPU, AP 등과 같은 범용 프로세서(30), GPU. VPU 등과 같은 그래픽 전용 프로세서(30) 또는 NPU와 같은 인공 지능 전용 프로세서(30)일 수 있다.
하나 또는 복수의 프로세서(30)는 비휘발성 메모리(20) 및 휘발성 메모리(20)에 저장된 기 정의된 동작 규칙 또는 인공 지능 모델에 따라, 입력 데이터를 처리하도록 제어한다. 기 정의된 동작 규칙 또는 인공 지능 모델은 학습을 통해 만들어진 것을 특징으로 한다.
여기서, 학습을 통해 만들어진다는 것은 다수의 학습 데이터들에 학습 알고리즘을 적용함으로써, 원하는 특성의 기 정의된 동작 규칙 또는 인공 지능 모델이 만들어짐을 의미한다. 이러한 학습은 본 개시에 따른 인공 지능이 수행되는 기기 자체에서 이루어질 수도 있고, 별도의 서버/시스템을 통해 이루어 질 수도 있다.
인공 지능 모델은, 복수의 신경망 레이어들로 구성될 수 있다. 각 레이어는 복수의 가중치(weight values)을 갖고 있으며, 이전(previous) 레이어의 연산 결과와 복수의 가중치의 연산을 통해 레이어의 연산을 수행한다. 신경망의 예로는, 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), GAN(Generative Adversarial Networks) 및 심층 Q-네트워크 (Deep Q-Networks)이 있으며, 본 개시에서의 신경망은 명시한 경우를 제외하고 전술한 예에 한정되지 않는다.
학습 알고리즘은, 다수의 학습 데이터들을 이용하여 소정의 대상 기기(예컨대, 로봇)을 훈련시켜 소정의 대상 기기 스스로 결정을 내리거나 예측을 할 수 있도록 하는 방법이다. 학습 알고리즘의 예로는, 지도형 학습(supervised learning), 비지도형 학습(unsupervised learning), 준지도형 학습(semi-supervised learning) 또는 강화 학습(reinforcement learning)이 있으며, 본 개시에서의 학습 알고리즘은 명시한 경우를 제외하고 전술한 예에 한정되지 않는다.
기기로 읽을 수 있는 저장매체는 비일시적(non-transitory) 저장매체의 형태로 제공될 수 있다. 여기서, '비일시적 저장매체'는 실재(tangible)하는 장치이고, 신호(signal)(예: 전자기파)를 포함하지 않는다는 것을 의미할 뿐이며, 이 용어는 데이터가 저장매체에 반영구적으로 저장되는 경우와 임시적으로 저장되는 경우를 구분하지 않는다. 예로, '비일시적 저장매체'는 데이터가 임시적으로 저장되는 버퍼를 포함할 수 있다.
일 실시 예에 따르면, 본 문서에 개시된 다양한 실시 예들에 따른 방법은 컴퓨터 프로그램 제품(computer program product)에 포함되어 제공될 수 있다. 컴퓨터 프로그램 제품은 상품으로서 판매자 및 구매자 간에 거래될 수 있다. 컴퓨터 프로그램 제품은 기기로 읽을 수 있는 저장 매체(예: compact disc read only memory (CD-ROM))의 형태로 배포되거나, 또는 어플리케이션 스토어(예: 플레이 스토어TM)를 통해 또는 두개의 사용자 장치들(예: 스마트폰들) 간에 직접, 온라인으로 배포(예: 다운로드 또는 업로드)될 수 있다. 온라인 배포의 경우에, 컴퓨터 프로그램 제품(예: 다운로더블 앱(downloadable app))의 적어도 일부는 제조사의 서버, 어플리케이션 스토어의 서버, 또는 중계 서버의 메모리(20)와 같은 기기로 읽을 수 있는 저장 매체에 적어도 일시 저장되거나, 임시적으로 생성될 수 있다.
이상에서 상술한 바와 같은 본 개시의 다양한 실시 예들에 따른 구성 요소(예: 모듈 또는 프로그램) 각각은 단수 또는 복수의 개체로 구성될 수 있으며, 전술한 해당 서브 구성 요소들 중 일부 서브 구성 요소가 생략되거나, 또는 다른 서브 구성 요소가 다양한 실시 예에 더 포함될 수 있다. 대체적으로 또는 추가적으로, 일부 구성 요소들(예: 모듈 또는 프로그램)은 하나의 개체로 통합되어, 통합되기 이전의 각각의 해당 구성 요소에 의해 수행되는 기능을 동일 또는 유사하게 수행할 수 있다.
다양한 실시 예들에 따른, 모듈, 프로그램 또는 다른 구성 요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱하게 실행되거나, 적어도 일부 동작이 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
한편, 본 개시에서 사용된 용어 "부" 또는 "모듈"은 하드웨어, 소프트웨어 또는 펌웨어로 구성된 유닛을 포함하며, 예를 들면, 로직, 논리 블록, 부품, 또는 회로 등의 용어와 상호 호환적으로 사용될 수 있다. "부" 또는 "모듈"은, 일체로 구성된 부품 또는 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수 있다. 예를 들면, 모듈은 ASIC(application-specific integrated circuit)으로 구성될 수 있다.
본 개시의 다양한 실시 예들은 기기(machine)(예: 컴퓨터)로 읽을 수 있는 저장 매체(machine-readable storage media에 저장된 명령어를 포함하는 소프트웨어로 구현될 수 있다. 기기는 저장 매체로부터 저장된 명령어를 호출하고, 호출된 명령어에 따라 동작이 가능한 장치로서, 개시된 실시 예들에 따른 전자 장치(예: 전자 장치(100))를 포함할 수 있다.
상기 명령이 프로세서에 의해 실행될 경우, 프로세서가 직접 또는 상기 프로세서의 제어 하에 다른 구성요소들을 이용하여 상기 명령에 해당하는 기능을 수행할 수 있다. 명령은 컴파일러 또는 인터프리터에 의해 생성 또는 실행되는 코드를 포함할 수 있다.
이상에서는 본 개시의 바람직한 실시 예에 대하여 도시하고 설명하였지만, 본 개시는 상술한 특정의 실시 예에 한정되지 아니하며, 청구범위에서 청구하는 본 개시의 요지를 벗어남이 없이 당해 개시가 속하는 기술분야에서 통상의 지식을 가진 자에 의해 다양한 변형실시가 가능한 것은 물론이고, 이러한 변형실시들은 본 개시의 기술적 사상이나 전망으로부터 개별적으로 이해되어서는 안 될 것이다.
100: 전자 장치
200: 제1 서버
300: 제2 서버 110: 통신 모듈
120: 메모리 130: 프로세서
300: 제2 서버 110: 통신 모듈
120: 메모리 130: 프로세서
Claims (19)
- 전자 장치에 있어서,
통신 모듈;
메모리; 및
상기 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하고,
상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하고,
상기 식별된 제2 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어하며,
상기 전송된 제2 데이터를 상기 메모리에서 삭제하고,
상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 통신 모듈을 통해 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하며,
상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하고,
상기 소프트웨어의 업데이트가 완료되면, 상기 통신 모듈을 통해 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 프로세서; 를 포함하는 전자 장치.
- 제1 항에 있어서,
상기 제2 데이터는 적어도 하나의 파일을 포함하고,
상기 프로세서는,
기 정의된 복수의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하며,
상기 복수의 결정 기준은 상기 메모리에서 상기 복수의 파일이 저장된 위치, 상기 복수의 파일의 크기, 상기 복수의 파일이 상기 메모리에 저장된 시간, 상기 복수의 파일의 형식, 상기 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 상기 복수의 파일의 중요도 중 적어도 하나를 포함하는 전자 장치.
- 제2 항에 있어서,
상기 프로세서는,
상기 복수의 파일 중 적어도 하나의 인물을 포함하는 이미지 파일이 식별되면, 상기 이미지 파일이 상기 사용자 프라이버시에 관련된 정보를 포함하는 것으로 식별하고,
상기 복수의 파일이 적어도 하나의 인물을 포함하는지 여부는 상기 복수의 파일 각각에 대한 메타데이터 및 상기 복수의 파일 각각을 객체 인식 모델에 입력함에 따라 획득된 객체 인식 결과 중 적어도 하나를 바탕으로 식별되는 전자 장치.
- 제2 항에 있어서,
상기 프로세서는,
상기 복수의 파일 별로 상기 복수의 결정 기준 각각에 대한 스코어를 획득하고,
상기 복수의 결정 기준 각각에 대한 스코어를 바탕으로 상기 복수의 파일 별 종합 스코어를 획득하며,
상기 복수의 파일 중 상기 종합 스코어가 기 설정된 임계 값 이상인 하나 이상의 파일을 상기 적어도 하나의 파일로 식별하는 전자 장치.
- 제1 항에 있어서,
상기 프로세서는,
상기 제2 데이터가 식별되면, 상기 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하고,
상기 제3 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어하며,
상기 소프트웨어의 업데이트가 완료되면, 상기 통신 모듈을 통해 상기 제1 서버로부터 상기 제3 데이터를 수신하고,
상기 수신된 제3 데이터를 복호화하여 상기 제2 데이터를 획득하며,
상기 획득된 제2 데이터를 상기 메모리에 저장하는 전자 장치.
- 제1 항에 있어서,
상기 소프트웨어를 업데이트하기 위한 요청은 상기 통신 모듈을 통해 상기 제2 서버로 전송된 업데이트 확인 요청에 따라 상기 제2 서버로부터 수신된 응답 또는 상기 소프트웨어를 업데이트하기 위한 제1 사용자 입력을 바탕으로 수신되는 전자 장치.
- 제2 항에 있어서,
디스플레이 모듈; 를 더 포함하고,
상기 프로세서는,
상기 잔여 용량이 상기 식별된 크기 미만이면, 상기 메모리에 저장된 복수의 파일 중 적어도 일부 파일에 대한 리스트를 포함하는 제1 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고,
상기 제1 사용자 인터페이스를 통해 상기 적어도 일부 파일 중 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력을 수신하고,
상기 제2 사용자 입력을 바탕으로 상기 제2 데이터를 식별하는 전자 장치.
- 제7 항에 있어서,
상기 프로세서는,
상기 제2 데이터가 식별되면, 상기 잔여 용량이 상기 식별된 크기 미만이라는 정보를 포함하는 제2 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고,
상기 제2 사용자 인터페이스를 통해 상기 제2 데이터를 상기 제1 서버로 전송하기 위한 제3 사용자 입력이 수신되면, 상기 제2 데이터를 상기 제1 서버로 전송하도록 상기 통신 모듈을 제어하는 전자 장치.
- 제7 항에 있어서,
상기 프로세서는,
상기 복수의 결정 기준에 대한 리스트를 포함하는 제3 사용자 인터페이스를 표시하도록 상기 디스플레이 모듈을 제어하고,
상기 제3 사용자 인터페이스를 통해 상기 복수의 결정 기준 중 적어도 하나의 결정 기준을 선택하는 제4 사용자 입력이 수신되면, 상기 적어도 하나의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하는 전자 장치.
- 전자 장치의 제어 방법에 있어서,
상기 전자 장치의 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계;
상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하는 단계;
상기 식별된 제2 데이터를 상기 제1 서버로 전송하는 단계;
상기 전송된 제2 데이터를 상기 메모리에서 삭제하는 단계;
상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하는 단계;
상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하는 단계; 및
상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 단계; 를 포함하는 전자 장치의 제어 방법.
- 제10 항에 있어서,
상기 제2 데이터는 적어도 하나의 파일을 포함하고,
상기 제2 데이터를 식별하는 단계는,
기 정의된 복수의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하는 단계; 를 포함하며,
상기 복수의 결정 기준은 상기 메모리에서 상기 복수의 파일이 저장된 위치, 상기 복수의 파일의 크기, 상기 복수의 파일이 상기 메모리에 저장된 시간, 상기 복수의 파일의 형식, 상기 복수의 파일이 사용자 프라이버시에 관련된 정보를 포함하는지 여부 및 상기 복수의 파일의 중요도 중 적어도 하나를 포함하는 전자 장치의 제어 방법.
- 제11 항에 있어서,
상기 제2 데이터를 식별하는 단계는,
상기 복수의 파일 중 적어도 하나의 인물을 포함하는 이미지 파일이 식별되면, 상기 이미지 파일이 상기 사용자 프라이버시에 관련된 정보를 포함하는 것으로 식별하는 단계; 를 더 포함하고,
상기 복수의 파일이 적어도 하나의 인물을 포함하는지 여부는 상기 복수의 파일 각각에 대한 메타데이터 및 상기 복수의 파일 각각을 객체 인식 모델에 입력함에 따라 획득된 객체 인식 결과 중 적어도 하나를 바탕으로 식별되는 전자 장치의 제어 방법.
- 제11 항에 있어서,
상기 제2 데이터를 식별하는 단계는,
상기 복수의 파일 별로 상기 복수의 결정 기준 각각에 대한 스코어를 획득하는 단계;
상기 복수의 결정 기준 각각에 대한 스코어를 바탕으로 상기 복수의 파일 별 종합 스코어를 획득하는 단계; 및
상기 복수의 파일 중 상기 종합 스코어가 기 설정된 임계 값 이상인 하나 이상의 파일을 상기 적어도 하나의 파일로 식별하는 단계; 를 더 포함하는 전자 장치의 제어 방법.
- 제10 항에 있어서,
상기 전자 장치의 제어 방법은,
상기 제2 데이터가 식별되면, 상기 식별된 제2 데이터를 암호화하여 제3 데이터를 획득하는 단계;
상기 제3 데이터를 상기 제1 서버로 전송하는 단계;
상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제3 데이터를 수신하는 단계;
상기 수신된 제3 데이터를 복호화하여 상기 제2 데이터를 획득하는 단계; 및
상기 획득된 제2 데이터를 상기 메모리에 저장하는 단계; 를 더 포함하는 전자 장치의 제어 방법.
- 제10 항에 있어서,
상기 소프트웨어를 업데이트하기 위한 요청은 상기 제2 서버로 전송된 업데이트 확인 요청에 따라 상기 제2 서버로부터 수신된 응답 또는 상기 소프트웨어를 업데이트하기 위한 제1 사용자 입력을 바탕으로 수신되는 전자 장치의 제어 방법.
- 제11 항에 있어서,
상기 전자 장치의 제어 방법은,
상기 잔여 용량이 상기 식별된 크기 미만이면, 상기 메모리에 저장된 복수의 파일 중 적어도 일부 파일에 대한 리스트를 포함하는 제1 사용자 인터페이스를 표시하는 단계;
상기 제1 사용자 인터페이스를 통해 상기 적어도 일부 파일 중 적어도 하나의 파일을 선택하기 위한 제2 사용자 입력을 수신하는 단계; 및
상기 제2 사용자 입력을 바탕으로 상기 제2 데이터를 식별하는 단계; 를 더 포함하는 전자 장치의 제어 방법.
- 제16 항에 있어서,
상기 전자 장치의 제어 방법은,
상기 제2 데이터가 식별되면, 상기 잔여 용량이 상기 식별된 크기 미만이라는 정보를 포함하는 제2 사용자 인터페이스를 표시하는 단계; 및
상기 제2 사용자 인터페이스를 통해 상기 제2 데이터를 상기 제1 서버로 전송하기 위한 제3 사용자 입력이 수신되면, 상기 제2 데이터를 상기 제1 서버로 전송하는 단계; 를 더 포함하는 전자 장치의 제어 방법.
- 제16 항에 있어서,
상기 전자 장치의 제어 방법은,
상기 복수의 결정 기준에 대한 리스트를 포함하는 제3 사용자 인터페이스를 표시하는 단계; 및
상기 제3 사용자 인터페이스를 통해 상기 복수의 결정 기준 중 적어도 하나의 결정 기준을 선택하는 제4 사용자 입력이 수신되면, 상기 적어도 하나의 결정 기준을 바탕으로 상기 메모리에 저장된 복수의 파일 중 상기 적어도 하나의 파일을 식별하는 단계; 를 더 포함하는 전자 장치의 제어 방법.
- 전자 장치의 제어 방법을 실행하는 프로그램을 포함하는 비일시적 컴퓨터 판독 가능 기록매체에 있어서,
상기 전자 장치의 제어 방법은,
상기 전자 장치의 메모리에 저장된 소프트웨어를 업데이트하기 위한 요청이 수신되면, 상기 업데이트를 위해 필요한 제1 데이터의 크기를 식별하는 단계;
상기 메모리의 잔여 용량이 상기 식별된 제1 데이터의 크기 미만이면, 상기 메모리에서 상기 식별된 제1 데이터의 크기에 대응되는 크기를 가지며 제1 서버에 백업될 제2 데이터를 식별하는 단계;
상기 식별된 제2 데이터를 상기 제1 서버로 전송하는 단계;
상기 전송된 제2 데이터를 상기 메모리에서 삭제하는 단계;
상기 제2 데이터가 상기 메모리에서 삭제되면, 상기 제2 서버로부터 상기 제1 데이터를 수신하여 상기 메모리에 저장하는 단계;
상기 메모리에 저장된 상기 제1 데이터를 바탕으로 상기 소프트웨어를 업데이트하는 단계; 및
상기 소프트웨어의 업데이트가 완료되면, 상기 제1 서버로부터 상기 제2 데이터를 수신하여 상기 메모리에 저장하는 단계; 를 포함하는 컴퓨터 판독 가능 기록매체.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020210021074A KR20220117569A (ko) | 2021-02-17 | 2021-02-17 | 전자 장치 및 전자 장치의 제어 방법 |
PCT/KR2021/019393 WO2022177120A1 (ko) | 2021-02-17 | 2021-12-20 | 전자 장치 및 전자 장치의 제어 방법 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020210021074A KR20220117569A (ko) | 2021-02-17 | 2021-02-17 | 전자 장치 및 전자 장치의 제어 방법 |
Publications (1)
Publication Number | Publication Date |
---|---|
KR20220117569A true KR20220117569A (ko) | 2022-08-24 |
Family
ID=82931795
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020210021074A KR20220117569A (ko) | 2021-02-17 | 2021-02-17 | 전자 장치 및 전자 장치의 제어 방법 |
Country Status (2)
Country | Link |
---|---|
KR (1) | KR20220117569A (ko) |
WO (1) | WO2022177120A1 (ko) |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100494629B1 (ko) * | 2003-03-28 | 2005-06-13 | 박종욱 | 네트워크를 이용한 파일관리 방법 |
KR101271780B1 (ko) * | 2005-12-06 | 2013-06-07 | 엘지전자 주식회사 | 이동 저장장치의 파일 관리 장치 및 방법 |
US7461223B2 (en) * | 2006-05-29 | 2008-12-02 | Microsoft Corporation | Retaining shadow copy data during replication |
KR20170126230A (ko) * | 2016-05-09 | 2017-11-17 | 한국전자통신연구원 | 펌웨어 업데이트 장치 및 방법, 그리고 펌웨어 업데이트 시스템 |
KR102200865B1 (ko) * | 2018-12-26 | 2021-01-11 | 인하대학교 산학협력단 | 이미지 데이터의 개인 정보 보호를 위한 방법 및 시스템 |
-
2021
- 2021-02-17 KR KR1020210021074A patent/KR20220117569A/ko unknown
- 2021-12-20 WO PCT/KR2021/019393 patent/WO2022177120A1/ko active Application Filing
Also Published As
Publication number | Publication date |
---|---|
WO2022177120A1 (ko) | 2022-08-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20240250833A1 (en) | Electronic device for processing multi-signed apk file, and operating method therefor | |
EP4258125A1 (en) | Electronic device and method for operation of storage of electronic device | |
EP4184403A1 (en) | Electronic device for generating transaction including internal data, and operating method thereof | |
US20230168831A1 (en) | Electronic device and operation method of electronic device for managing storage space | |
EP4198742A1 (en) | Electronic device and storage management method using same | |
KR20220117569A (ko) | 전자 장치 및 전자 장치의 제어 방법 | |
US20230359530A1 (en) | Electronic device for supporting data backup, and operation method thereof | |
US12019906B2 (en) | Electronic device and method of electronic device operating file system using data compression and memory partition | |
US11995798B2 (en) | Electronic device and method for managing non-destructive editing contents | |
KR20240111666A (ko) | 비-파괴 편집 기능을 제공하는 방법 및 이를 지원하는 전자 장치 | |
US20230306668A1 (en) | Electronic device and method for managing information for creating avatar of electronic device | |
US20230367915A1 (en) | Electronic device for displaying security image, and method for operating same | |
EP4432113A1 (en) | Operation method of electronic device for file search, and electronic device thereof | |
EP4394617A1 (en) | Electronic device and method for operating file system of electronic device | |
KR20220127504A (ko) | 블록 장치 이미지에 대한 런타임 체크섬 검증을 수행하는 전자 장치 및 이의 동작 방법 | |
US20240179234A1 (en) | Electronic device for processing plurality of pieces of information, and operating method therefor | |
KR20240079126A (ko) | 전자 장치 및 전자 장치의 쿠키 정보 관리 방법 | |
KR20220139684A (ko) | 저장 공간을 관리하는 방법 및 이를 지원하는 전자 장치 | |
KR20230068230A (ko) | 전자 장치의 초기화 상황에서 데이터 보존 방법 및 그 전자 장치 | |
KR20220126903A (ko) | 파일 리댁션을 수행하는 전자 장치 및 이의 동작 방법 | |
KR20240047866A (ko) | 파일을 공유하는 전자 장치, 방법, 및 비일시적 컴퓨터 판독가능 저장 매체 | |
KR20220060336A (ko) | 내부 데이터가 포함된 트랜잭션을 생성하는 전자 장치 및 이의 동작 방법 | |
KR20240066940A (ko) | 손상된 메타데이터를 복구하기 위한 방법 및 이를 지원하는 전자 장치 | |
KR20240015538A (ko) | 데이터를 관리하는 전자 장치 및 데이터 관리 방법 | |
KR20220109093A (ko) | 전자 장치 및 이의 제어 방법 |