KR20170128239A - Customizable functional patterns for optical barcodes - Google Patents

Customizable functional patterns for optical barcodes Download PDF

Info

Publication number
KR20170128239A
KR20170128239A KR1020177023059A KR20177023059A KR20170128239A KR 20170128239 A KR20170128239 A KR 20170128239A KR 1020177023059 A KR1020177023059 A KR 1020177023059A KR 20177023059 A KR20177023059 A KR 20177023059A KR 20170128239 A KR20170128239 A KR 20170128239A
Authority
KR
South Korea
Prior art keywords
image
shape feature
data
custom
feature
Prior art date
Application number
KR1020177023059A
Other languages
Korean (ko)
Other versions
KR102018143B1 (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 스냅 인코포레이티드
Publication of KR20170128239A publication Critical patent/KR20170128239A/en
Application granted granted Critical
Publication of KR102018143B1 publication Critical patent/KR102018143B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1439Methods for optical code recognition including a method step for retrieval of the optical code
    • G06K7/1443Methods for optical code recognition including a method step for retrieval of the optical code locating of the code in an image
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06037Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking multi-dimensional coding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06046Constructional details
    • G06K19/06103Constructional details the marking being embedded in a human recognizable image, e.g. a company logo with an embedded two-dimensional code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06046Constructional details
    • G06K19/06131Constructional details the marking comprising a target pattern, e.g. for indicating the center of the bar code or for helping a bar code reader to properly orient the scanner or to retrieve the bar code inside of an image
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1408Methods for optical code recognition the method being specifically adapted for the type of code
    • G06K7/14131D bar codes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1408Methods for optical code recognition the method being specifically adapted for the type of code
    • G06K7/14172D bar codes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1439Methods for optical code recognition including a method step for retrieval of the optical code
    • G06K7/1456Methods for optical code recognition including a method step for retrieval of the optical code determining the orientation of the optical code with respect to the reader and correcting therefore
    • G06K9/3216
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/20Image preprocessing
    • G06V10/24Aligning, centring, orientation detection or correction of the image
    • G06V10/245Aligning, centring, orientation detection or correction of the image by locating a pattern; Special marks for positioning

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Artificial Intelligence (AREA)
  • Health & Medical Sciences (AREA)
  • Electromagnetism (AREA)
  • General Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Multimedia (AREA)
  • User Interface Of Digital Computer (AREA)
  • Studio Devices (AREA)

Abstract

광학 바코드용 맞춤형 기능 패턴을 위한 시스템 및 방법이 제공된다. 예시적인 실시예에서, 이미지의 이미지 데이터가 사용자 디바이스로부터 수신된다. 이미지 데이터로부터 이미지의 후보 형상 피쳐(shape feature)가 추출된다. 형상 피쳐가 형상 피쳐 규칙을 만족한다는 결정이 이루어진다. 후보 형상 피쳐가 형상 피쳐 규칙을 만족하는 것에 응답하여, 후보 형상 피쳐를 맞춤형 그래픽의 기준 형상 피쳐와 비교함으로써 이미지 내의 맞춤형 그래픽이 식별된다. 맞춤형 그래픽을 식별하는 것에 응답하여, 이미지의 일부 내에 인코딩된 데이터가 디코딩된다.A system and method for a customized functional pattern for an optical bar code is provided. In an exemplary embodiment, image data of an image is received from a user device. A candidate shape feature of the image is extracted from the image data. A determination is made that the shape feature satisfies the shape feature rule. In response to the candidate shape feature satisfying the shape feature rule, the customized graphics in the image are identified by comparing the candidate shape feature to the reference shape feature of the custom graphics. In response to identifying the custom graphics, the encoded data within a portion of the image is decoded.

Description

광학 바코드에 대한 맞춤형 기능 패턴들Customizable functional patterns for optical barcodes

본 국제 출원은, 참조로 그 각각의 전체 내용이 본 명세서에 포함되는, 2015년 8월 14일 출원된 발명의 명칭이 "CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES"인 미국 출원 제14/826,301호, 2015년 2월 3일 출원된 발명의 명칭이 "CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES"인 미국 출원 제14/612,409호, 및 2015년 1월 19일 출원된 발명의 명칭이 "CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES"인 미국 가출원 제62/105,141호의 우선권을 주장한다.This international application is a continuation-in-part of US Application No. 14 / 826,301, entitled " CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES " filed August 14, 2015, the entire contents of each of which are incorporated herein by reference, U.S. Application Serial No. 14 / 612,409, entitled "CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES", filed Feb. 3, and U.S. Patent Application Serial No. 10 / 612,409, filed January 19, 2015 entitled "CUSTOM FUNCTIONAL PATTERNS FOR OPTICAL BARCODES" 62 / 105,141, which is incorporated herein by reference in its entirety.

본 개시내용의 실시예들은 대체로 모바일 컴퓨팅 기술에 관한 것으로, 더 구체적으로는, 광학 바코드에 대한 맞춤형 기능 패턴에 관한 것이지만, 이것으로 제한되는 것은 아니다.Embodiments of the present disclosure generally relate to mobile computing technologies, and more particularly, but not exclusively, to customizable functional patterns for optical barcodes.

빠른 응답(QR; Quick Response) 코드, 및 기타의 광학 바코드는, 모바일 디바이스, 착용형 디바이스, 및 기타의 스마트 디바이스의 사용자들에게 소량의 정보를 공유하는 편리한 방식이다. 통상적으로, 광학 바코드는 광학 바코드의 식별을 위한 파인더 패턴(finder pattern)을 이용한다. 종래의 파인더 패턴은 통상적으로, 광학 바코드 내에 눈에 띄게 배치된 복수의 일반 마킹(generic marking)을 이용한다. 이러한 눈에 띄는 일반 마킹은 보기 흉할 수 있으며 종종 파인더 패턴으로 기능하는 것 이외의 용도로는 역할하지 않는다.Quick Response (QR) codes, and other optical bar codes are a convenient way to share a small amount of information to users of mobile devices, wearable devices, and other smart devices. Typically, the optical bar code uses a finder pattern for identification of the optical bar code. Conventional finder patterns typically use a plurality of generic markings that are prominently placed within the optical bar code. These prominent generic markings can be unsightly and often do not serve any purpose other than to function as a finder pattern.

첨부된 도면의 다양한 도면들은 본 개시내용의 예시적인 실시예를 나타낼 뿐이고 그 범위를 제한하는 것으로서 간주되어서는 안 된다.
도 1은 일부 예시적인 실시예에 따른 네트워킹된 시스템을 나타내는 블록도이다.
도 2는 일부 예시적인 실시예에 따른 맞춤형 패턴 시스템의 예시적인 실시예를 나타내는 블록도이다.
도 3a 및 도 3b는 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 채용한 광학 바코드의 예를 나타내는 도면이다.
도 4는 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 채용한 광학 바코드를 식별 및 디코딩하는 예를 나타내는 도면이다.
도 5는 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하고 디코딩하는 예시적인 방법을 나타내는 흐름도이다.
도 6은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하는 추가의 예시적인 동작을 나타내는 흐름도이다.
도 7은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용한 광학 바코드를 식별하는 예를 나타내는 도면이다.
도 8은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다.
도 9는 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용한 광학 바코드를 식별하는 예를 나타내는 도면이다.
도 10은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다.
도 11은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용한 광학 바코드를 디코딩하기 위한 예를 나타내는 도면이다.
도 12a, 도 12b, 및 도 12c는, 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하는 것을 가능하게 하는데 이용되는 다양한 이미지 변환을 나타내는 도면이다.
도 13은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다.
도 14는 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하는 예를 나타내는 도면이다.
도 15는 일부 예시적인 실시예에 따른 광학 바코드를 식별하기 위한 예시적인 사용자 인터페이스를 도시하는 사용자 인터페이스도이다.
도 16은 일부 예시적인 실시예에 따른 광학 바코드와 연관된 동작을 수행하기 위한 예시적인 사용자 인터페이스를 도시하는 사용자 인터페이스도이다.
도 17은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 생성하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다.
도 18은 일부 예시적인 실시예에 따른 맞춤형 기능 패턴을 이용하여 광학 바코드를 생성하기 위한 예시적인 사용자 인터페이스를 도시하는 사용자 인터페이스도이다.
도 19는 일부 예시적인 실시예에 따른 예시적인 모바일 디바이스 및 모바일 운영 체제 인터페이스를 도시하는 사용자 인터페이스도이다.
도 20은 일부 예시적인 실시예에 따른 머신 상에 설치될 수 있는 소프트웨어 아키텍쳐의 예를 나타내는 블록도이다.
도 21은 예시적인 실시예에 따른 머신으로 하여금 여기서 논의된 방법들 중 임의의 것을 수행하게 하기 위해 명령어 세트가 실행될 수 있는 컴퓨터 시스템의 형태의 머신의 개략도를 도시하는 블록도이다.
The various figures of the accompanying drawings are merely representative of the exemplary embodiments of the present disclosure and are not to be construed as limiting the scope thereof.
1 is a block diagram illustrating a networked system in accordance with some exemplary embodiments.
2 is a block diagram illustrating an exemplary embodiment of a custom pattern system in accordance with some exemplary embodiments.
Figs. 3A and 3B are views showing examples of optical barcodes employing a customized function pattern according to some exemplary embodiments. Fig.
4 is an illustration showing an example of identifying and decoding an optical barcode employing a customized function pattern according to some exemplary embodiments.
5 is a flow diagram illustrating an exemplary method for identifying and decoding an optical bar code using a customized function pattern according to some exemplary embodiments.
6 is a flow diagram illustrating further exemplary operation for identifying an optical bar code using a customized function pattern according to some exemplary embodiments.
7 is a diagram showing an example of identifying an optical barcode using a customized function pattern according to some exemplary embodiments.
Figure 8 is a flow diagram illustrating further exemplary operation for identifying an optical bar code using a customized function pattern according to some exemplary embodiments.
9 is a diagram showing an example of identifying an optical barcode using a customized function pattern according to some exemplary embodiments.
10 is a flow diagram illustrating a further exemplary operation for decoding an optical bar code using a customized function pattern according to some exemplary embodiments.
11 is a diagram showing an example for decoding an optical barcode using a customized function pattern according to some exemplary embodiments.
Figures 12A, 12B, and 12C are diagrams illustrating various image transformations used to enable decoding of optical bar codes using a customizable function pattern according to some exemplary embodiments.
Figure 13 is a flow diagram illustrating further exemplary operation for decoding an optical bar code using a customized function pattern according to some exemplary embodiments.
14 is a diagram showing an example of decoding an optical bar code using a customized function pattern according to some exemplary embodiments.
15 is a user interface diagram illustrating an exemplary user interface for identifying optical barcodes in accordance with some exemplary embodiments.
Figure 16 is a user interface diagram illustrating an exemplary user interface for performing operations associated with optical barcodes according to some exemplary embodiments.
17 is a flow diagram illustrating further exemplary operation for creating an optical bar code using a customized function pattern according to some exemplary embodiments.
18 is a user interface diagram illustrating an exemplary user interface for creating an optical barcode using a customized function pattern according to some exemplary embodiments.
19 is a user interface diagram illustrating an exemplary mobile device and mobile operating system interface in accordance with some exemplary embodiments.
20 is a block diagram illustrating an example of a software architecture that may be installed on a machine in accordance with some example embodiments.
21 is a block diagram illustrating a schematic diagram of a machine in the form of a computer system in which a set of instructions may be executed to cause the machine according to the illustrative embodiment to perform any of the methods discussed herein.

이하의 설명은 본 개시내용의 예시적인 실시예들을 구현하는 시스템, 방법, 기술, 명령어 시퀀스 및 컴퓨팅 머신 프로그램 제품을 포함한다. 이하의 설명에서, 설명의 목적을 위해, 많은 구체적인 상세사항이 본 발명의 주제의 다양한 실시예에 대한 이해를 제공하기 위해 개시된다. 그러나, 본 기술분야의 통상의 기술자에게는, 본 발명의 주제의 실시예들은 이러한 구체적인 상세사항 없이도 실시될 수 있다는 것이 명백할 것이다.The following description includes systems, methods, techniques, instruction sequences and computing machine program products that implement the exemplary embodiments of the present disclosure. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide an understanding of various embodiments of the subject matter of the present invention. However, it will be apparent to one of ordinary skill in the art that embodiments of the subject matter of the present invention may be practiced without these specific details.

일반적으로, 널리 공지된 명령어 인스턴스, 프로토콜, 구조 및 기술은 반드시 상세하게 도시되지는 않는다.In general, well-known instruction instances, protocols, structures, and techniques are not necessarily shown in detail.

QR 코드, 및 기타의 광학 바코드(예를 들어, 유니버설 제품 코드(UPC) 바코드, Aztec 코드, Data Matrix, Dataglyph, MaxiCode, PDF417, Ultra Code)는, 모바일 디바이스, 착용형 디바이스, 및 기타의 스마트 디바이스의 사용자들과 소량의 정보를 공유하는 편리한 방식이다. 예를 들어, QR 코드는, 카메라 센서가 장착된 디바이스(예를 들어, 스마트 폰)에 의해 판독가능한 정보를 인코딩하는 2차원 광학 바코드이다. 전형적으로, QR 코드는, QR 코드의 식별 및 인식에 이용되는 파인더 패턴 또는 디코딩을 가능하게 하는데 이용되는 정렬 패턴 등의, 하나 이상의 기능 패턴을 포함한다. 종래의 파인더 패턴은, (QR 코드의 경우에서와 같이) 우측 하단 코너를 제외한 모든 코너에 배치된 사각형 마크 등의 디자인에서 일반적인 복수의 마크를 포함한다. 이러한 파인더 패턴은, 곡선, 불균일 및 기타의 멋진 요소들 등의 심미적 요소가 없으며 종종 광학 바코드의 개방적 이용을 촉진하기 위해 특정한 표준을 준수한다.QR codes, and other optical bar codes (e.g., Universal Product Code (UPC) bar codes, Aztec codes, Data Matrix, Dataglyph, MaxiCode, PDF417, Ultra Code) It's a convenient way to share a small amount of information with your users. For example, the QR code is a two-dimensional optical barcode that encodes information that can be read by a device (e.g., a smartphone) equipped with a camera sensor. Typically, the QR code comprises one or more functional patterns, such as a finder pattern used to identify and recognize a QR code, or an alignment pattern used to enable decoding. Conventional finder patterns include a plurality of marks common in designs such as square marks placed at all corners except the lower right corner (as in the case of QR codes). These finder patterns do not have aesthetic elements such as curves, irregularities, and other cool elements, and often adhere to certain standards to facilitate the open use of optical barcodes.

다양한 예시적인 실시예에서, 맞춤형 또는 비표준 기능 패턴을 이용하는 광학 바코드는, 광학 바코드와 연관된 고급 경험을 가능하게 하는 심미적으로 만족스러운 브랜드화된 바코드를 사용자에게 제공한다. 예를 들어, 엔티티 로고(예를 들어, 회사, 조직 또는 개인의 로고)가 파인더 패턴, 또는 일부 경우에는 정렬 패턴으로서 이용되어, 그 엔티티에 의해 제공된 소프트웨어를 이용하여 머신-판독가능한 브랜드화되고 고급화된 광학 바코드를 생성할 수 있다. 특정한 예에서, "스냅코드"는 SNAPCHAT®로고를 기능 패턴으로 이용하는 광학 바코드이다.In various exemplary embodiments, optical barcodes utilizing custom or non-standard functional patterns provide users with an aesthetically pleasing branded barcode that enables an advanced experience associated with optical barcodes. For example, an entity logo (e.g., company, organization, or personal logo) may be used as a finder pattern, or in some cases an alignment pattern, to provide a machine- An optical bar code can be generated. In a particular example, a "snap code" is an optical bar code that uses the SNAPCHAT® logo as a functional pattern.

한 예시적인 실시예에서, 맞춤형 패턴 시스템은 사용자 디바이스로부터 이미지를 나타내는 이미지 데이터를 수신한다. 예를 들어, 맞춤형 패턴 시스템은 사용자의 스마트 폰의 광학 센서(예를 들어, 카메라 센서)로부터 이미지 데이터를 수신한다. 다양한 실시예에서, 사용자 디바이스로부터의 이미지 데이터는, 사용자 개시형 이미지 포착, 사용자 디바이스의 광학 센서에 의해 검출된 이미지 데이터의 주기적 모니터링, 저장된 이미지 데이터의 액세스, 또는 이들의 조합에 응답하여 수신된다. 이미지 데이터의 일부는, 특정한 기능 패턴(예를 들어, 파인더 패턴)에 대한 맞춤형 그래픽을 채용하는 광학 바코드를 나타내는 데이터를 포함할 수 있다. 일부 시나리오에서, 이미지 데이터는, 광학 바코드에 관련된 데이터와 함께 이질적인 또는 관련없는 데이터를 포함한다(예를 들어, 광학 바코드의 이미지는 광학 바코드를 디코딩하는 것과 관련이 없는 배경을 포함한다). 특정한 예에서, 사용자 디바이스의 광학 센서는 특정한 광학 바코드를 포함하는 홍보 포스터의 이미지를 포착한다. 홍보 포스터의 이미지는, 특정한 광학 바코드와 함께, 그 특정한 광학 바코드를 둘러싸는 관련없는 부분들, 즉, 홍보 포스터 또는 배경을 포함할 수 있다.In one exemplary embodiment, the custom pattern system receives image data representing an image from a user device. For example, a custom pattern system receives image data from an optical sensor (e.g., a camera sensor) of a user's smartphone. In various embodiments, image data from a user device is received in response to user-initiated image capture, periodic monitoring of image data detected by an optical sensor of a user device, access to stored image data, or a combination thereof. A portion of the image data may include data representing an optical barcode that employs custom graphics for a particular functional pattern (e.g., a finder pattern). In some scenarios, the image data includes heterogeneous or irrelevant data along with data related to the optical bar code (e.g., the image of the optical bar code includes a background unrelated to decoding the optical bar code). In a particular example, the optical sensor of the user device captures an image of a promotional poster comprising a specific optical bar code. The image of the promotional poster may include irrelevant portions surrounding the particular optical bar code, such as a promotional poster or background, along with a specific optical bar code.

맞춤형 패턴 시스템이 이미지 데이터를 수신한 후, 맞춤형 패턴 시스템은 맞춤형 그래픽에 대한 이미지의 이미지 데이터를 검색하여 그 이미지가 광학 바코드를 포함하는지를 결정한다. 즉, 맞춤형 그래픽은, 이미지 내의 광학 바코드의 인식, 식별 또는 검출을 위한 파인더 패턴으로 이용된다. 한 예시적인 실시예에서, 맞춤형 패턴 시스템은, 이미지 데이터로부터 후보 형상 피쳐 또는 복수의 후보 형상 피쳐들을 추출함으로써 맞춤형 그래픽을 검색한다. 예를 들어, 맞춤형 패턴 시스템은, 엣지 검출 기술 또는 다른 이미지 처리 기술을 수행하여, 이미지의 윤곽선 등의 후보 형상 피쳐를 식별한다. 그 다음, 맞춤형 패턴 시스템은 후보 형상 피쳐가 형상 피쳐 규칙 또는 기준을 만족시키는지를 결정한다. 예를 들어, 특정한 후보 형상 피쳐가 윤곽선이라면, 맞춤형 패턴 시스템은 윤곽선이 이미지의 일부를 둘러싸는 둘러싸인 폐곡선인지를 결정할 수 있다. 일부 실시예와 일치하여, 형상 피쳐 규칙은, 무관하거나 이질적인 후보 형상 피쳐 또는 맞춤형 그래픽일 확률이 낮은 후보 형상 피쳐를 필터링 제거한다.After the custom pattern system receives the image data, the custom pattern system retrieves the image data of the image for the custom graphic to determine if the image contains the optical bar code. That is, the customized graphic is used as a finder pattern for recognition, identification, or detection of the optical barcode in the image. In one exemplary embodiment, the custom pattern system retrieves custom graphics by extracting candidate feature features or a plurality of candidate feature features from the image data. For example, a custom pattern system performs edge detection techniques or other image processing techniques to identify candidate shape features, such as contours of an image. The custom pattern system then determines if the candidate shape feature satisfies the shape feature rule or criterion. For example, if a particular candidate shape feature is an outline, the customized pattern system can determine if the outline is an enclosed closed curve surrounding a portion of the image. Consistent with some embodiments, the feature feature rules filter out candidate feature features that are unlikely to be irrelevant or heterogeneous candidate feature features or customizable graphics.

형상 피쳐 규칙을 만족하는 후보 형상 피쳐에 응답하여, 맞춤형 패턴 시스템은, 후보 형상 피쳐를 맞춤형 그래픽의 기준 형상 피쳐와 비교함으로써 맞춤형 그래픽을 식별한다. 예를 들어, 맞춤형 패턴 시스템은 후보 형상 피쳐의 면적 또는 크기를 기준 형상 피쳐의 기준 면적 또는 크기와 비교할 수 있다. 이 예에서, 맞춤형 패턴 시스템은 후보 형상 피쳐와 기준 형상 피쳐 사이의 일치 또는 준일치(예를 들어, 임계값보다 높은 백분율 일치)에 기초하여 맞춤형 그래픽을 식별한다. 이러한 방식으로, 맞춤형 패턴 시스템은 맞춤형 그래픽을 파인더 패턴으로 이용하여 이미지의 일부 내에서 광학 바코드의 존재를 식별한다.In response to the candidate shape feature that satisfies the shape feature rule, the custom pattern system identifies the customized graphic by comparing the candidate shape feature with the reference shape feature of the custom graphic. For example, the custom pattern system may compare the area or size of the candidate shape feature to the reference area or size of the reference feature feature. In this example, the custom pattern system identifies a custom graphic based on a match or a sub match (e.g., a percentage match above the threshold) between the candidate feature feature and the reference feature feature. In this manner, the custom pattern system utilizes custom graphics as a finder pattern to identify the presence of optical barcodes within a portion of the image.

추가의 예시적인 실시예에서, 맞춤형 그래픽은, 맞춤형 패턴 시스템이 광학 바코드에 인코딩된 데이터를 디코딩하는 것을 가능하게하는 정렬 패턴으로서 기능한다. 한 예시적인 실시예에서, 맞춤형 패턴 시스템은 이미지 데이터로부터 이미지 내의 맞춤형 그래픽의 공간적 속성을 추출한다. 예를 들어, 맞춤형 패턴 시스템은 이미지 데이터로부터 맞춤형 그래픽의 위치, 스케일 또는 배향(orientation)을 추출한다. 맞춤형 패턴 시스템은, 이미지 내의 맞춤형 그래픽의 공간적 속성을 이용하여 이미지 데이터로부터 이미지 내에 인코딩된 데이터를 디코딩한다. 예를 들어, 맞춤형 패턴 시스템은 공간적 속성(예를 들어, 디-스큐, 회전, 스케일, 또는 또 다른 타입의 이미지 변환)을 이용하여 이미지 변환을 수행하여 이미지의 일부에 인코딩된 데이터의 검출능/신뢰성을 향상시킬 수 있다. 이러한 방식으로, 맞춤형 패턴 시스템은 맞춤형 그래픽을 정렬 패턴으로서 이용하여 광학 바코드의 디코딩을 가능하게 한다.In a further exemplary embodiment, the custom graphic serves as an alignment pattern that enables the custom pattern system to decode the data encoded in the optical bar code. In one exemplary embodiment, the custom pattern system extracts the spatial attributes of the custom graphics within the image from the image data. For example, a custom pattern system extracts the position, scale, or orientation of a custom graphic from image data. The custom pattern system decodes the encoded data within the image from the image data using the spatial properties of the customized graphics in the image. For example, a custom pattern system may perform image conversion using spatial attributes (e.g., de-skew, rotate, scale, or another type of image conversion) to detect / Reliability can be improved. In this manner, a custom pattern system utilizes custom graphics as an alignment pattern to enable decoding of the optical bar code.

따라서, 맞춤형 패턴 시스템은, 종래의 기능 패턴을 이용하지 않고 맞춤형 그래픽을 광학 바코드의 기능 패턴으로서 이용한다. 맞춤형 그래픽을 기능 패턴으로서 이용하는 것은 심미적으로 만족스러운 디자인을 허용하고, 기능 패턴이 반드시 공개 표준을 따를 필요는 없어서 특정한 소프트웨어 애플리케이션에 의해서만 판독될 수 있기 때문에 특정한 소프트웨어 애플리케이션에 독점성을 제공할 수 있다.Therefore, the customized pattern system uses the customized graphic as the functional pattern of the optical bar code without using the conventional function pattern. Using custom graphics as a functional pattern allows for an aesthetically pleasing design and can provide proprietary functionality to a particular software application since the functional pattern does not necessarily have to follow an open standard and can only be read by a particular software application.

도 1은, 한 실시예에 따라, 네트워크를 통해 데이터를 교환하도록 구성된 클라이언트-서버 아키텍쳐를 갖는 네트워크 시스템(100)을 도시하는 네트워크 도면이다. 예를 들어, 네트워크 시스템(100)은 클라이언트가 네트워크 시스템(100) 내에서 통신하고 데이터를 교환하는 메시징 시스템일 수 있다. 데이터는 네트워크 시스템(100) 및 그 사용자와 연관된 다양한 기능(예를 들어, 텍스트 및 미디어 통신신호의 전송 및 수신, 위치 정보의 결정 등) 및 양태에 관련될 수 있다. 여기서는 클라이언트-서버 아키텍쳐로 예시되었지만, 다른 실시예는 피어-투-피어 또는 분산 네트워크 환경 등의 다른 네트워크 아키텍쳐를 포함할 수 있다.1 is a network diagram illustrating a network system 100 having a client-server architecture configured to exchange data over a network, according to one embodiment. For example, network system 100 may be a messaging system in which a client communicates within network system 100 and exchanges data. The data may relate to various aspects of the network system 100 and its various functions (e.g., transmission and reception of text and media communication signals, determination of location information, etc.) and aspects. Although illustrated herein with a client-server architecture, other embodiments may include other network architectures such as peer-to-peer or distributed network environments.

도 1에 도시된 바와 같이, 네트워크 시스템(100)은 소셜 메시징 시스템(130)을 포함한다. 소셜 메시징 시스템(130)은 일반적으로, 인터페이스 계층(124), 애플리케이션 로직 계층(126), 및 데이터 계층(128)으로 구성된 3-계층 아키텍쳐에 기초한다. 관련 컴퓨터 및 인터넷 관련 분야의 통상의 기술자라면 이해하는 바와 같이, 도 1에 도시된 각각의 모듈 또는 엔진은 실행가능한 소프트웨어 명령어 세트 및 명령어를 실행하기 위한 대응하는 하드웨어(예를 들어, 메모리 및 프로세서)를 나타낸다. 불필요한 상세사항으로 본 발명의 주제를 모호하게 하는 것을 피하기 위해, 본 발명의 주제를 전달하는 것과 밀접하지 않은 다양한 기능 모듈 및 엔진은 도 1에서 생략되었다.As shown in FIG. 1, network system 100 includes a social messaging system 130. The social messaging system 130 is generally based on a three-tier architecture comprising an interface layer 124, an application logic layer 126, and a data layer 128. As will be appreciated by those of ordinary skill in the relevant computer and Internet arts, each module or engine shown in FIG. 1 includes an executable set of software instructions and corresponding hardware (e.g., memory and processor) . In order to avoid obscuring the subject matter of the present invention with unnecessary details, various functional modules and engines that are not closely related to conveying the subject matter of the present invention have been omitted from FIG.

물론, 여기서 구체적으로 설명되지 않은 추가 기능을 가능하게 하기 위해, 도 1에 나타낸 것 등의 추가 기능 모듈 및 엔진이 소셜 메시징 시스템과 함께 이용될 수 있다. 또한, 도 1에 도시된 다양한 기능 모듈들 및 엔진들은 단일 서버 컴퓨터 상에 존재할 수 있거나, 다양한 구조로 여러 서버 컴퓨터들에 걸쳐 분산될 수 있다. 또한, 소셜 메시징 시스템(130)이 도 1에서는 3-계층 아키텍쳐로서 도시되어 있지만, 본 발명의 주제는 결코 이러한 아키텍쳐로 제한되지 않는다.Of course, additional feature modules and engines such as those shown in Figure 1 may be used with the social messaging system to enable additional functionality not specifically described herein. In addition, the various functional modules and engines illustrated in FIG. 1 may reside on a single server computer, or may be distributed across multiple server computers in various configurations. Also, while the social messaging system 130 is shown in FIG. 1 as a three-tiered architecture, the subject matter of the present invention is by no means limited to such an architecture.

도 1에 도시된 바와 같이, 인터페이스 계층(124)은, 클라이언트 애플리케이션(112)을 실행하는 클라이언트 디바이스(110) 및 제3자 애플리케이션(122)을 실행하는 제3자 서버(120) 등의, 다양한 클라이언트 컴퓨팅 디바이스 및 서버로부터 요청을 수신하는, 인터페이스 모듈(예를 들어, 웹 서버)(140)로 구성된다. 수신된 요청에 응답하여, 인터페이스 모듈(140)은 적절한 응답을 네트워크(104)를 통해 요청 디바이스들에 전달한다. 예를 들어, 인터페이스 모듈(140)은, HTTP(Hypertext Transfer Protocol) 요청, 또는 기타의 웹 기반 API(Application Programming Interface) 요청 등의 요청을 수신할 수 있다.As shown in Figure 1, the interface layer 124 may be implemented in various ways, such as a client device 110 executing a client application 112 and a third party server 120 executing a third party application 122 (E. G., A web server) 140 that receives requests from a client computing device and a server. In response to the received request, the interface module 140 forwards the appropriate response to the requesting devices via the network 104. For example, the interface module 140 may receive a request, such as a Hypertext Transfer Protocol (HTTP) request, or other web-based API (Application Programming Interface) request.

클라이언트 디바이스(110)는, 다양한 모바일 컴퓨팅 디바이스 및 모바일-특유의 운영 체제(예를 들어, IOS™, ANDROID™, WINDOWS® PHONE)를 포함하는 특정한 플랫폼을 위해 개발된 종래의 웹 브라우저 애플리케이션 또는 애플리케이션들(또한 "앱"이라고도 함)을 실행할 수 있다. 한 예에서, 클라이언트 디바이스(110)는 클라이언트 애플리케이션(112)을 실행하고 있다. 클라이언트 애플리케이션(112)은, 사용자(106)에게 정보를 프리젠팅하고 네트워크(104)를 통해 전달하여 소셜 메시징 시스템(130)과 정보를 교환하는 기능을 제공할 수 있다. 클라이언트 디바이스(110)들 각각은 소셜 메시징 시스템(130)에 액세스하기 위해 적어도 디스플레이 및 네트워크(104)와의 통신 능력을 포함하는 컴퓨팅 디바이스를 포함할 수 있다. 클라이언트 디바이스(110)는, 원격 디바이스, 워크스테이션, 컴퓨터, 범용 컴퓨터, 인터넷 어플라이언스, 핸드헬드 디바이스, 무선 디바이스, 휴대형 디바이스, 착용형 컴퓨터, 셀룰러 또는 모바일 전화, 개인 휴대 정보 단말기(PDA), 스마트폰, 태블릿, 울트라북, 넷북, 랩탑, 데스크탑, 멀티-프로세서 시스템, 마이크로프로세서 기반의 또는 프로그래밍가능한 가전 제품, 게임 콘솔, 셋탑 박스, 네트워크 PC, 미니 컴퓨터 등을 포함하지만, 이것으로 제한되지 않는다. 사용자(106)는, 사람, 머신, 또는 클라이언트 디바이스(110)와 상호작용하는 기타의 수단을 포함할 수 있다. 일부 실시예에서, 사용자(106)는 클라이언트 디바이스(110)를 통해 소셜 메시징 시스템(130)과 상호작용한다.The client device 110 may be a conventional web browser application or applications developed for a particular platform, including various mobile computing devices and mobile-specific operating systems (e.g., IOS ™, ANDROID ™, WINDOWS® PHONE) (Also referred to as "apps"). In one example, client device 110 is executing client application 112. The client application 112 may provide functionality for presenting information to the user 106 and communicating over the network 104 to exchange information with the social messaging system 130. Each of the client devices 110 may include a computing device including at least a display and communication capability with the network 104 for accessing the social messaging system 130. [ The client device 110 may be a wireless device such as a remote device, a workstation, a computer, a general purpose computer, an Internet appliance, a handheld device, a wireless device, a portable device, a wearable computer, a cellular or mobile phone, a personal digital assistant , Tablet, ultrabook, netbook, laptop, desktop, multi-processor system, microprocessor-based or programmable consumer electronics, game console, set-top box, network PC, minicomputer and the like. The user 106 may include a person, machine, or other means for interacting with the client device 110. In some embodiments, the user 106 interacts with the social messaging system 130 via the client device 110.

도 1에 도시된 바와 같이, 데이터 계층(128)은 정보 스토리지 저장소 또는 데이터베이스(134)로의 액세스를 가능하게 하는 하나 이상의 데이터베이스 서버(132)를 갖는다. 데이터베이스(134)는, 멤버 프로파일 데이터, 소셜 그래프 데이터(예를 들어, 소셜 메시징 시스템(130)의 멤버들 사이의 관계), 및 기타의 사용자 데이터 등의 데이터를 저장하는 스토리지 디바이스이다.As shown in FIG. 1, the data layer 128 has one or more database servers 132 that enable access to an information storage repository or database 134. The database 134 is a storage device that stores data such as member profile data, social graph data (e.g., relationships among members of the social messaging system 130), and other user data.

개인은 소셜 메시징 시스템(130)에 등록하여 소셜 메시징 시스템(130)의 멤버가 될 수 있다. 일단 등록되고 나면, 멤버는 소셜 메시징 시스템(130) 상에서 소셜 네트워크 관계(예를 들어, 친구, 팔로워, 또는 접촉자)를 형성할 수 있고, 소셜 메시징 시스템(130)에 의해 제공되는 광범위한 애플리케이션과 상호작용할 수 있다.An individual may register with the social messaging system 130 and become a member of the social messaging system 130. Once registered, a member may form a social network relationship (e.g., a friend, a follower, or a contact) on the social messaging system 130 and may interact with a wide range of applications provided by the social messaging system 130 .

애플리케이션 로직 계층(126)은 다양한 애플리케이션 로직 모듈(150)을 포함하며, 애플리케이션 로직 모듈(150)은, 인터페이스 모듈(140)과 연계하여, 데이터 계층(128) 내의 다양한 데이터 소스 또는 데이터 서비스로부터 회수된 데이터를 갖춘 다양한 사용자 인터페이스를 생성한다. 개개의 애플리케이션 로직 모듈(150)은, 소셜 메시징 시스템(130)의 다양한 애플리케이션, 서비스 및 피쳐들과 연관된 기능을 구현하는데 이용될 수 있다. 예를 들어, 소셜 메시징 애플리케이션은 애플리케이션 로직 모듈(150)들 중 하나 이상으로 구현될 수 있다. 소셜 메시징 애플리케이션은, 클라이언트 디바이스(110)의 사용자가 텍스트 및 화상 및 비디오 등의 미디어 콘텐츠를 포함하는 메시지를 송수신하기 위한 메시징 메커니즘을 제공한다. 클라이언트 디바이스(110)는 명시된 기간(예를 들어, 제한된 또는 무제한) 동안 소셜 메시징 애플리케이션으로부터의 메시지를 액세스하고 볼 수 있다. 한 예에서, 특정한 메시지는, 특정한 메시지가 처음 액세스될 때 시작하는 (예를 들어, 메시지 전송자에 의해 지정된) 미리 정의된 기간 동안 메시지 수신자에게 액세스될 수 있다. 미리 정의된 기간이 경과한 후에, 메시지는 삭제되고 더 이상 메시지 수신자에게 액세스될 수 없다. 물론, 다른 애플리케이션 및 서비스들은 그들 자신의 애플리케이션 로직 모듈(150)에서 별개로 구현될 수 있다.The application logic layer 126 includes a variety of application logic modules 150 that may be associated with the interface module 140 to provide various data sources or data services Create various user interfaces with data. Each application logic module 150 may be used to implement functions associated with various applications, services, and features of the social messaging system 130. For example, the social messaging application may be implemented with one or more of the application logic modules 150. The social messaging application provides a messaging mechanism for a user of the client device 110 to send and receive messages, including text and media content such as video and video. The client device 110 may access and view messages from the social messaging application for a specified period of time (e.g., limited or unlimited). In one example, a particular message may be accessed by the message recipient for a predefined period of time (e.g., specified by the message sender) that starts when the particular message is first accessed. After a predefined period of time has elapsed, the message is deleted and can no longer be accessed by the message recipient. Of course, other applications and services may be implemented separately in their own application logic module 150.

도 1에 나타낸 바와 같이, 소셜 메시징 시스템(130) 또는 클라이언트 애플리케이션(112)은 맞춤형 기능 패턴을 채용하는 광학 바코드를 식별하고 디코딩하는 기능을 제공하는 맞춤형 패턴 시스템(160)을 포함한다. 다양한 실시예에서, 맞춤형 패턴 시스템(160)은 독립형 시스템으로서 구현될 수 있고, 반드시 소셜 메시징 시스템(130)에 포함되는 것은 아니다. 일부 실시예에서, 클라이언트 디바이스(110)는 맞춤형 패턴 시스템(160)의 일부를 포함한다(예를 들어, 맞춤형 패턴 시스템(160)의 일부는 독립적으로 또는 클라이언트 애플리케이션(112) 내에 포함될 수 있다). 클라이언트 디바이스(110)가 맞춤형 패턴 시스템(160)의 일부를 포함하는 실시예들에서, 클라이언트 디바이스(110)는, 특정한 애플리케이션 서버에 포함되거나 소셜 메시징 시스템(130)에 포함된 맞춤형 패턴 시스템(160)의 부분과 연계하여 또는 단독으로 작동할 수 있다.As shown in FIG. 1, the social messaging system 130 or client application 112 includes a custom pattern system 160 that provides the ability to identify and decode optical barcodes employing custom function patterns. In various embodiments, the custom pattern system 160 may be implemented as a stand alone system, and is not necessarily included in the social messaging system 130. In some embodiments, client device 110 includes a portion of custom pattern system 160 (e.g., a portion of custom pattern system 160 may be included independently or within client application 112). In embodiments in which the client device 110 includes a portion of the custom pattern system 160, the client device 110 may include a custom pattern system 160 included in a particular application server or included in the social messaging system 130, Or may operate alone.

도 2는 맞춤형 패턴 시스템(160)의 블록도(200)이다.FIG. 2 is a block diagram 200 of a custom pattern system 160. FIG.

맞춤형 패턴 시스템(160)은, 통신 모듈(210), 프리젠테이션 모듈(220), 파인더 모듈(230), 정렬 모듈(240), 디코더 모듈(250), 동작 모듈(260), 및 인코더 모듈(270)을 포함하는 것으로 도시되어 있다. 모듈들(210-270)의 전부 또는 일부는, 예를 들어, 네트워크 결합, 공유된 메모리 등을 통해 서로 통신한다. 모듈들(210-270)의 각각의 모듈은 단일 모듈로서 구현되거나, 다른 모듈들과 결합되거나, 또는 복수의 모듈들로 더 세분될 수 있다. 예시적인 실시예들과 관련이 없는 다른 모듈들도 역시 포함될 수 있지만, 도시되지는 않는다.The custom pattern system 160 includes a communication module 210, a presentation module 220, a finder module 230, an alignment module 240, a decoder module 250, an operation module 260, and an encoder module 270 ). ≪ / RTI > All or a portion of the modules 210-270 communicate with each other via, for example, network coupling, shared memory, and the like. Each module of modules 210-270 may be implemented as a single module, combined with other modules, or further subdivided into a plurality of modules. Other modules not related to the illustrative embodiments may also be included, but are not shown.

통신 모듈(210)은 다양한 통신 기능을 제공한다. 예를 들어, 통신 모듈(210)은 사용자 디바이스로부터 이미지의 이미지 데이터를 수신, 액세스 또는 기타의 방식으로 획득한다. 특정한 예에서, 통신 모듈(210)은 스마트 폰의 카메라 센서로부터 실질적으로 실시간 이미지 데이터(예를 들어, 스마트 폰의 카메라 센서에 의해 포착된 단일 프레임의 이미지 데이터 또는 프레임들의 연속 스트림)를 수신한다. 통신 모듈(210)은, 데이터베이스 서버(132), 클라이언트 디바이스(110), 및 제3자 서버(120)와 네트워크 통신신호를 교환한다. 통신 모듈(210)에 의해 회수된 정보는, 본 명세서에 설명된 기능을 가능하게 하기 위해 사용자와 연관된 데이터(예를 들어, 온라인 계정으로부터의 멤버 프로파일 데이터 또는 소셜 네트워크 서비스 데이터) 또는 기타의 데이터를 포함한다.The communication module 210 provides various communication functions. For example, communication module 210 receives, accesses or otherwise acquires image data of an image from a user device. In a particular example, communication module 210 receives substantially real-time image data (e.g., a continuous stream of image data or frames of a single frame captured by a camera sensor of a smartphone) from the camera sensor of the smartphone. The communication module 210 exchanges network communication signals with the database server 132, the client device 110, and the third party server 120. The information retrieved by communication module 210 may include data associated with a user (e.g., member profile data from an online account or social network service data) or other data to enable the functionality described herein .

프리젠테이션 모듈(220)은, 사용자에게 대화식으로 정보를 프리젠팅하고 사용자로부터 정보를 수신하도록 동작가능한 다양한 프리젠테이션 및 사용자 인터페이스 기능을 제공한다. 예를 들어, 프리젠테이션 모듈(220)은 광학 바코드의 디코딩에 응답하여 생성된 사용자 인터페이스를 프리젠팅하는데 이용가능하다. 다른 사례에서, 프리젠테이션 모듈(220)은 광학 바코드(들)를 포함하는 사용자 인터페이스를 생성한다. 다양한 실시예에서, 프리젠테이션 모듈(220)은 정보를 프리젠팅하거나 정보의 프리젠테이션을 야기한다(예를 들어, 스크린 상에 시각적으로 정보를 디스플레이하는 것, 음향 출력, 햅틱 피드백). 대화식으로 정보를 프리젠팅하는 프로세스는 특정한 디바이스와 사용자 사이에서의 정보의 교환을 포함하도록 의도되어 있다. 사용자는, 영숫자, 포인트 기반(예를 들어, 커서), 촉각적, 또는 기타의 입력(예를 들어, 터치 스크린, 촉각 센서, 광 센서, 적외선 센서, 바이오메트릭 센서, 마이크로폰, 자이로스코프, 가속도계, 또는 기타의 센서) 등의 많은 가능한 방식으로 사용자 인터페이스와 상호작용하기 위한 입력을 제공할 수 있다. 프리젠테이션 모듈(220)은 여기서 설명된 기능을 가능하게 하기 위해 많은 다른 사용자 인터페이스를 제공한다. 본 명세서에서 사용된 용어 "프리젠팅(presenting)"은, 전달된 정보 또는 명령어들에 기초하여 프리젠테이션을 수행하도록 동작가능한 특정한 디바이스에 정보 또는 명령어를 전달하는 것을 포함한다.Presentation module 220 provides various presentation and user interface functions that are operable to present information to the user interactively and to receive information from the user. For example, the presentation module 220 is available to present the user interface generated in response to decoding of the optical bar code. In another example, the presentation module 220 creates a user interface that includes the optical bar code (s). In various embodiments, the presentation module 220 may present information or cause presentation of the information (e.g., visually displaying information on the screen, acoustic output, haptic feedback). The process of interactively presenting information is intended to involve the exchange of information between a particular device and a user. The user may select one or more of the following: alphanumeric, point based (e.g., cursor), tactile, or other input (e.g., touch screen, tactile sensor, optical sensor, infrared sensor, biometric sensor, microphone, gyroscope, accelerometer, Or other sensors), for example, to provide an input for interacting with the user interface. The presentation module 220 provides many different user interfaces to enable the functionality described herein. The term "presenting " as used herein includes conveying information or instructions to a specific device that is operable to perform a presentation based on the information or commands conveyed.

파인더 모듈(230)은, 광학 바코드에서 파인더 패턴으로서 채용중인 맞춤형 그래픽을 식별, 인식, 또는 검출하기 위한 이미지 처리 기능을 제공한다. 예를 들어, 파인더 모듈(230)은, 사용자 디바이스(예컨대, 클라이언트 디바이스(110))로부터 수신된 이미지의 이미지 데이터로부터 후보 형상 피쳐 또는 후보 윤곽선 특성을 추출하고 분석한다. 파인더 모듈(230)은 추출된 후보 형상 피쳐와 연관된 다양한 규칙 또는 기준의 만족도를 결정한다. 파인더 모듈(230)은 추출된 후보 형상 피쳐를 맞춤형 그래픽의 기준 형상 피쳐 또는 다른 기준 이미지와 비교하여 이미지에 포함된 맞춤형 그래픽을 식별한다. 파인더 모듈(230)은 이미지의 이미지 데이터로부터 후보 형상 피쳐를 추출하고 후속해서 후보 형상 피쳐의 분석에 기초하여 맞춤형 그래픽을 식별하기 위한 다양한 방식 및 기술을 채용할 수 있다. 이들 기술의 예는 도 5 내지 도 14와 관련하여 후술된다.The finder module 230 provides an image processing function for identifying, recognizing, or detecting a customized graphic being employed as a finder pattern in an optical bar code. For example, the finder module 230 extracts and analyzes candidate feature or candidate contour properties from the image data of the image received from the user device (e.g., client device 110). The finder module 230 determines the satisfaction of various rules or criteria associated with the extracted candidate shape features. The finder module 230 identifies the custom graphics contained in the image by comparing the extracted candidate shape features with a reference shape feature or other reference image of the custom graphics. The finder module 230 may employ various schemes and techniques for extracting candidate shape features from the image data of the image and subsequently identifying the customized graphics based on analysis of the candidate shape features. Examples of these techniques are described below with respect to Figures 5-14.

정렬 모듈(240)은 맞춤형 그래픽을 이용하여 광학 바코드의 정렬을 결정하기 위한 이미지 처리 기능을 제공한다. 맞춤형 패턴 시스템(160)은 정렬을 이용하여 광학 바코드에 인코딩된 데이터의 디코딩을 가능하게 할 수 있다. 이러한 방식으로 맞춤형 그래픽은 광학 바코드에 대한 정렬 패턴으로서 기능한다. 예를 들어, 정렬 모듈(240)은 이미지 데이터로부터 이미지 내의 맞춤형 그래픽의 공간적 속성을 추출한다. 다양한 실시예들에서, 공간적 속성은, 광학 바코드의 위치, 배향, 스케일, 또는 다른 공간적 양태 중 적어도 하나를 포함한다. 정렬 모듈(240)은 공간적 속성(예를 들어, 광학 바코드의 특정한 배향)에 기초하여 광학 바코드의 정렬을 결정한다. 한 예에서, 정렬 모듈(240)은 공간적 속성에 기초하여 위치 및 배향을 포함하는 정렬을 결정하고 정렬에 따라 변환된 이미지를 생성할 수 있다. 맞춤형 패턴 시스템(160)은 변환된 이미지를 이용하여 변환된 이미지의 일부 내의 인코딩된 데이터를 디코딩할 수 있다.Alignment module 240 provides image processing functions for determining alignment of optical bar codes using custom graphics. The custom pattern system 160 may enable alignment of the data encoded in the optical bar code. In this way, the custom graphic functions as an alignment pattern for the optical bar code. For example, the sorting module 240 extracts spatial attributes of the custom graphics within the image from the image data. In various embodiments, the spatial attribute includes at least one of the position, orientation, scale, or other spatial aspects of the optical bar code. Alignment module 240 determines the alignment of the optical bar code based on spatial attributes (e.g., a particular orientation of the optical bar code). In one example, the alignment module 240 may determine an alignment that includes position and orientation based on spatial attributes and generate an image that is transformed in accordance with the alignment. The custom pattern system 160 may use the transformed image to decode the encoded data within a portion of the transformed image.

디코더 모듈(250)은 이미지 내의 맞춤형 그래픽의 공간적 속성 또는 결정된 정렬을 이용하여 이미지 내에 인코딩된 데이터를 디코딩하는 기능을 제공한다. 예를 들어, 디코더 모듈(250)은 이미지 데이터로부터 추출된 맞춤형 그래픽의 공간적 속성에 따라 변환된 이미지로부터 이미지 내에 인코딩된 데이터를 디코딩할 수 있다. 한 실시예에서, 디코더 모듈(250)은 이미지 데이터로부터 이미지의 일부 내에 인코딩된 데이터를 나타내는 마킹(예를 들어, 높은 콘트라스트 도트, 사각형, 또는 이미지 내의 다른 마크)을 검출한다. 특정한 예에서, 디코더 모듈(250)은 이미지 내에 인코딩된 데이터를 디코딩하기 위해 Reed-Solomon 에러 정정 방식을 이용한다. Reed-Solomon 에러 정정 방식은 광학 바코드로부터 소정 백분율의 데이터(예를 들어, 손상된 비트 또는 부정확하게 디코딩된 비트)를 디코딩할 수 없는 경우에도 성공적이거나 유효한 디코딩을 허용한다. 일부 실시예에서, 맞춤형 패턴 시스템(160)의 사용자 또는 관리자는 광학 바코드를 디코딩할 때 허용가능한 손상되거나 부정확하게 디코딩된 데이터의 양에 대한 용인 값을 구성한다. 일부 실시예에서, 디코더 모듈(250)은 또한, 광학 바코드의 디코딩을 개선하는 이미지 처리 기능을 제공한다. 예를 들어, 디코더 모듈(250)뿐만 아니라 정렬 모듈(240)은 이미지의 이미지 변환을 수행할 수 있다(예를 들어, 이미지 선명화, 노이즈제거 처리, 기타의 디지털 필터링, 또는 디코딩 정확도를 개선시키는 기타의 이미지 처리 기술을 수행).Decoder module 250 provides the ability to decode data encoded within an image using spatial properties or determined alignment of the custom graphics within the image. For example, the decoder module 250 may decode encoded data in the image from the transformed image according to spatial properties of the custom graphics extracted from the image data. In one embodiment, the decoder module 250 detects markings (e.g., high contrast dots, squares, or other marks in the image) representing data encoded within a portion of the image from the image data. In a particular example, the decoder module 250 uses the Reed-Solomon error correction scheme to decode the encoded data in the image. The Reed-Solomon error correction scheme allows successful or valid decoding even when it is not possible to decode a certain percentage of the data (e.g., corrupted bits or incorrectly decoded bits) from the optical bar code. In some embodiments, the user or manager of custom pattern system 160 constructs an acceptance value for the amount of corrupted or incorrectly decoded data that is acceptable when decoding the optical bar code. In some embodiments, the decoder module 250 also provides an image processing function that improves the decoding of the optical bar code. For example, the decoder module 250 as well as the alignment module 240 may perform image transformation of the image (e.g., image sharpening, noise reduction processing, other digital filtering, or improving the decoding accuracy Perform other image processing techniques).

동작 모듈(260)은 이미지 내에 인코딩된 데이터를 디코딩하는 것에 기초하여 다양한 동작을 수행하는 기능을 제공한다. 예를 들어, 이미지의 일부 내에 인코딩된 데이터는 특정한 동작을 나타낼 수 있거나 특정한 동작과 연계하여 이용될 정보를 포함할 수 있다. 특정한 예에서, 이미지의 일부 내에 인코딩된 데이터는 소셜 네트워킹 서비스의 멤버의 사용자 이름 또는 기타의 사용자 식별을 포함할 수 있으며, 사용자 이름을 디코딩하는 것에 기초하여, 동작 모듈(260)은 사용자 이름에 대응하는 소셜 네트워킹 서비스에 관한 동작을 수행할 수 있다(예를 들어, 사용자 이름과 연관된 멤버에게 메시지 보내기). 일부 실시예에서, 동작 모듈(260)은 이미지를 스캔하는 특정한 앱에 대해 특유한 동작(예를 들어, 그 앱의 사용자에게는 이용가능하지만 다른 경우에는 이용불가능한 기능)을 수행한다. 일부 예에서, 동작 모듈(260)은 외부 서버와 통신하지 않고 동작을 수행한다(예를 들어, 스냅코드를 스캔한 사용자 디바이스 상에서 국지적으로 수행된 동작).The action module 260 provides the ability to perform various actions based on decoding the encoded data in the image. For example, data encoded within a portion of an image may represent a particular action or may include information to be used in conjunction with a particular action. In a particular example, the data encoded within a portion of the image may include a username or other user identification of a member of the social networking service, and based on decoding the username, the action module 260 may respond to the username (E.g., sending a message to a member associated with a user name). In some embodiments, the action module 260 performs actions specific to the particular app that is scanning the image (e.g., a function available to the user of the app, but otherwise unavailable). In some instances, the action module 260 performs an action (e.g., an action performed locally on the user device that scanned the snap code) without communicating with an external server.

인코더 모듈(270)은 데이터를 생성하고 인코딩하여, 맞춤형 그래픽을 하나 이상의 기능 패턴으로서 채용하는 광학 바코드화하는 기능을 제공한다(예를 들어, 스냅코드를 생성). 디코더 모듈(250)과 관련하여 앞서 논의된 바와 같이, 특정한 예에서, 인코더 모듈(270)은 Reed-Solomon 에러 정정 등의 기술을 채용하여 데이터를 인코딩할 수 있다. 한 예시적인 실시예에서, 인코더 모듈(270)은 인코딩될 데이터를 나타내는 머신-판독가능한 마크들의 배열을 렌더링한다. 그 다음, 인코더 모듈(270)은 렌더링된 마크들의 배열 및 기능 패턴으로서 이용될 맞춤형 그래픽을 이용하여 머신-판독가능한 광학 바코드를 생성할 수 있다.Encoder module 270 provides (e.g., generates a snap code) the ability to create and encode data to optically barcode to employ custom graphics as one or more functional patterns. As discussed above in connection with decoder module 250, in a particular example, encoder module 270 may employ data encoding techniques such as Reed-Solomon error correction. In one exemplary embodiment, the encoder module 270 renders an array of machine-readable marks representing the data to be encoded. The encoder module 270 may then generate a machine-readable optical bar code using the custom graphics to be used as an array of rendered marks and a functional pattern.

도 3a 및 도 3b는 파인더 패턴 또는 정렬 패턴에 대한 맞춤형 그래픽을 이용하는 광학 바코드의 예(예를 들어, 스냅코드)를 도시하는 도면이다. 도면(300)은, 맞춤형 그래픽(310)(예를 들어, 회사 로고), 및 인코딩되어 광학 바코드화된 데이터를 나타내는 마킹(320)을 포함하는 예시적인 광학 바코드를 도시한다. 이 예에서, 맞춤형 그래픽(310)은 SNAPCHAT®"유령" 로고 등의 회사 로고이다. SNAPCHAT®"유령" 로고는 단지 예시적인 맞춤형 그래픽이고 다른 그래픽, 아이콘, 또는 심볼들이 여기서 설명된 기술을 이용하여 파인더 패턴 또는 정렬 패턴으로서 이용될 수 있다는 것을 이해할 것이다. 기능 패턴으로서 이용되는 다른 예제 맞춤형 그래픽은, 복수의 경로, 복수의 다각형, 복수의 심미적 요소, 또는 기타의 디자인 피쳐를 포함할 수 있다.3A and 3B are diagrams showing examples (e.g., snap codes) of an optical bar code using a custom graphic for a finder pattern or an alignment pattern. Drawing 300 illustrates an exemplary optical barcode that includes a custom graphic 310 (e.g., a company logo) and a marking 320 that is encoded to indicate optically barcoded data. In this example, the custom graphic 310 is a company logo such as the SNAPCHAT® "ghost" logo. It will be appreciated that the SNAPCHAT® "Ghost" logo is merely exemplary custom graphics and that other graphics, icons, or symbols may be used as a finder pattern or an alignment pattern using the techniques described herein. Other example custom graphics used as a functional pattern may include a plurality of paths, a plurality of polygons, a plurality of aesthetic elements, or other design features.

도면(300)에 도시된 바와 같이, 마킹(320)은, 머신에 의해 판독가능한 특정한 간격 또는 위치를 갖는 패턴으로 배열된 도트들이다. 도면(300)이 마킹(320)을 도트들로서 도시하고 있지만, 다른 형상 및 마크가 채용될 수 있다(예를 들어, 사각형 또는 다양한 기하학적 구조의 비대칭 형상들). 마킹(320)은 균일한 패턴 또는 불균일한 패턴으로 배열될 수 있다. 일부 경우에, 마크들은 상이한 크기 또는 균일한 크기일 수 있다. 또한, 마킹(320)은 미리결정된 배열이거나 마킹으로부터 데이터를 디코딩할 때 동적으로 결정될 수 있는 배열일 수 있다. 일부 실시예에서, 맞춤형 그래픽(310) 및 마킹(320)은, 외곽 박스(325) 등의 경계 형상에 의해 둘러싸일 수 있다. 도면(300)의 외곽 박스(325)는 둥근 코너를 갖는 사각형으로서 도시되어 있지만, 외곽 박스(325)는 다양한 기하학적 구조를 갖는 다양한 다른 형상으로 된 형태일 수 있다. 도 3b의 도면(330)은 파인더 패턴 또는 정렬 패턴을 위한 맞춤형 그래픽을 채용하는 또 다른 예시적인 광학 바코드를 도시한다. 도면(330)은 맞춤형 그래픽으로부터 배제된 마킹들을 갖는 광학 바코드를 도시한다. 이들 및 다른 실시예에서, 맞춤형 그래픽 내부의 공간은 다른 용도를 위해 예약될 수 있다. 예를 들어, 그림, 그래픽, 애니메이션, 주석, 또는 사용자에 의해 선택된 이미지가 삽입될 수 있다.As shown in the diagram 300, the markings 320 are dots arranged in a pattern having a specific spacing or position readable by the machine. Although illustration 300 depicts markings 320 as dots, other shapes and marks may be employed (e.g., asymmetric shapes of a rectangle or various geometries). The markings 320 may be arranged in a uniform pattern or a non-uniform pattern. In some cases, the marks may be of different sizes or of a uniform size. In addition, marking 320 can be a predetermined arrangement or an arrangement that can be dynamically determined when decoding data from a marking. In some embodiments, the custom graphic 310 and marking 320 may be surrounded by a border shape, such as the outer box 325, or the like. Although the outer box 325 of the drawing 300 is shown as a square with rounded corners, the outer box 325 may be in a variety of different shapes with various geometries. Drawing 330 in FIG. 3B shows another exemplary optical barcode employing a custom graphic for the finder pattern or alignment pattern. Drawing 330 shows an optical bar code with markings excluded from the custom graphics. In these and other embodiments, the space within the custom graphics may be reserved for other uses. For example, pictures, graphics, animations, annotations, or images selected by the user can be inserted.

이제 도 4를 참조하면, 파인더 패턴 또는 정렬 패턴에 대한 맞춤형 그래픽을 채용하는 광학 바코드를 식별하고 디코딩하는 예를 나타내는 도면(400)이 도시되어 있다. 도 4는 맞춤형 그래픽을 이용하여 광학 바코드를 식별 및 디코딩하는 특정한 예시적인 실시예의 개요이다. 추가의 상세사항들 및 대안적인 구현들이 후속되는 도면들과 관련하여 논의된다. 도면(400)에서, 장면(402)은 광학 바코드(406)를 포함하는 포스터(404)와 사용자(410)를 도시한다.Referring now to FIG. 4, there is shown a drawing 400 illustrating an example of identifying and decoding an optical barcode employing custom graphics for a finder pattern or an alignment pattern. Figure 4 is an overview of a specific exemplary embodiment for identifying and decoding optical bar codes using custom graphics. Additional details and alternative implementations are discussed in connection with the following figures. In the drawing 400, a scene 402 shows a poster 404 and a user 410 that include an optical bar code 406.

광학 바코드(406)는, 사용자 디바이스 디스플레이, 컴퓨터 디스플레이 상에, 의류 또는 다른 제품에 직조되거나 기타의 방식으로 부착되거나, 또는 다양한 인쇄물에 포함되는 등의, 다양한 방식으로 디스플레이될 수 있다는 것을 이해할 것이다. 콜아웃(412)은 장면(402)의 일부의 확대도를 나타낸다. 콜아웃(412)은, 광학 바코드(406)의 광학 신호(408)를 검출하도록 동작가능한 광학 센서(예를 들어, 스마트 폰의 카메라 센서)를 포함하는 사용자(410)의 사용자 디바이스(414)를 포함한다.It will be appreciated that the optical bar code 406 may be displayed in a variety of ways, such as on a user device display, a computer display, woven or otherwise attached to a garment or other article, or included in various prints. Callout 412 represents an enlarged view of a portion of scene 402. The callout 412 includes a user device 414 of a user 410 that includes an optical sensor (e.g., a camera sensor of a smart phone) operable to detect an optical signal 408 of the optical bar code 406 .

한 예시적인 실시예에서, 사용자 디바이스(414)는 광학 바코드(406)를 포함하는 포스터(404)의 이미지를 포착한다. 맞춤형 패턴 시스템(160)은 사용자 디바이스(414)로부터 이미지를 나타내는 이미지 데이터를 수신한다. 이 예시적인 실시예에서, 맞춤형 패턴 시스템(160)은 사용자 디바이스(414)(예를 들어, 사용자(410)의 스마트 폰 상에서 실행중인 애플리케이션)에 포함되지만, 다른 예시적인 실시예에서는, 맞춤형 패턴 시스템(160)은 사용자 디바이스(414)와 통신가능하게 결합된 서버(예를 들어, 소셜 메시징 시스템(130)의 서버) 상에 존재할 수 있다. 콜아웃(416)은, 파인더 모듈(230)이 이미지에서 맞춤형 그래픽을 식별하고 맞춤형 그래픽을 광학 바코드(406)에 포함된 데이터를 디코딩하기 위한 정렬 패턴으로서 이용하기 위해 수행하는 예시적인 이미지 처리를 나타낸다. 콜아웃(416)에서, 파인더 모듈(230)은 이미지의 이미지 데이터로부터 후보 형상 피쳐를 추출한다. 후속해서, 파인더 모듈(230)은 후보 피쳐가 소정의 규칙 및 기준을 만족하는지를 결정하여 무관한 형상 피쳐 또는 맞춤형 그래픽일 확률이 낮은 형상 피쳐를 필터링 제거한다. 그 다음, 파인더 모듈(230)은, 형상 피쳐 기준 또는 규칙을 만족하는 후보 형상 피쳐를, 맞춤형 그래픽의 기준 형상 피쳐와 비교할 수 있다. 한 예에서, 파인더 모듈(230)은 후보 형상 피쳐와 기준 형상 피쳐 사이의 일치에 기초하여(예를 들어, 임계값을 초과하는 일치 점수) 맞춤형 그래픽을 식별한다.In one exemplary embodiment, the user device 414 captures an image of a poster 404 that includes an optical bar code 406. The custom pattern system 160 receives image data representing an image from the user device 414. In this exemplary embodiment, the custom pattern system 160 is included in a user device 414 (e.g., an application running on the smartphone of the user 410), but in another exemplary embodiment, (E.g., a server of the social messaging system 130) that is communicatively coupled to the user device 414. [ The callout 416 represents exemplary image processing performed by the finder module 230 to identify custom graphics in the image and to utilize the custom graphics as an alignment pattern for decoding the data contained in the optical bar code 406 . At callout 416, the finder module 230 extracts candidate feature features from the image data of the image. Subsequently, the finder module 230 determines whether the candidate feature meets certain rules and criteria to filter out low-probability feature features that are irrelevant or customizable graphics. The finder module 230 may then compare the candidate feature features that meet the shape feature criteria or rules with the customized graphics reference feature features. In one example, the finder module 230 identifies a customized graphic based on a match between the candidate feature feature and the reference feature feature (e.g., a match score that exceeds a threshold).

파인더 모듈(230)이 맞춤형 그래픽을 식별하는 것에 후속하여, 맞춤형 패턴 시스템(160)은 맞춤형 그래픽을 디코딩을 위한 정렬 패턴으로서 이용할 수 있다. 예를 들어, 정렬 모듈(240)은 이미지에서 맞춤형 그래픽의 공간적 속성을 추출하고 추출된 공간적 속성을 기준 공간적 속성과 비교하여 맞춤형 그래픽의 정렬을 결정한다. 정렬 모듈(240) 또는 디코더 모듈(250)은, 콜아웃(418)에 도시된 바와 같이 정렬(예를 들어, 회전 또는 디스큐)에 따라 이미지의 변환된 이미지를 생성할 수 있다. 변환된 이미지를 생성한 후, 디코더 모듈(250)은, 콜아웃(420)에 도시된 바와 같은 변환된 이미지의 일부 내에 인코딩된 데이터를 디코딩한다. 콜아웃(420)에서, 광학 바코드(406)의 도트들은 도트에 대해 1 및 비도트에 대해 0으로서 도시된 데이터로 변환되지만, 이것은 단지 예시적인 것이며, 다른 방식이 패용될 수도 있다. 이러한 방식으로, 맞춤형 패턴 시스템(160)은, 광학 바코드(406)에 포함된 맞춤형 그래픽을 파인더 패턴 또는 정렬 패턴 등의 하나 이상의 기능 패턴으로서 이용한다.Following the identification of the custom graphics by the finder module 230, the custom pattern system 160 may utilize the custom graphics as an alignment pattern for decoding. For example, the sort module 240 extracts the spatial attributes of the custom graphics from the image and compares the extracted spatial attributes with the reference spatial attributes to determine the alignment of the custom graphics. Alignment module 240 or decoder module 250 may generate a transformed image of the image according to alignment (e.g., rotation or deskew) as shown in callout 418. [ After generating the transformed image, the decoder module 250 decodes the encoded data within a portion of the transformed image as shown in the callout 420. In the callout 420, the dots of the optical bar code 406 are converted to data shown as 1 for dots and 0 for non-dots, but this is merely exemplary and other schemes may be exploited. In this manner, the custom pattern system 160 utilizes the custom graphics contained in the optical bar code 406 as one or more functional patterns, such as a finder pattern or an alignment pattern.

도 5는 맞춤형 기능 패턴을 채용하는 광학 바코드(예를 들어, 도 4의 광학 바코드(406))에 대한 예시적인 방법(500)을 나타내는 흐름도이다. 방법(500)의 동작들은 맞춤형 패턴 시스템(160)의 컴포넌트들에 의해 수행될 수 있고, 이하에서는 예시의 목적을 위해 설명된다.FIG. 5 is a flow chart illustrating an exemplary method 500 for an optical bar code employing a custom function pattern (e.g., optical bar code 406 of FIG. 4). The operations of method 500 may be performed by components of custom pattern system 160 and are described below for illustrative purposes.

동작 510에서, 통신 모듈(210)은 사용자 디바이스로부터 이미지의 이미지 데이터를 수신한다. 예를 들어, 통신 모듈(210)은 사용자의 스마트 폰의 광학 센서(예를 들어, 카메라 센서)로부터 이미지 데이터를 수신한다. 다양한 실시예에서, 사용자 디바이스로부터의 이미지 데이터는, 사용자 개시형 이미지 포착, 사용자 디바이스의 광학 센서에 의해 검출되는 이미지 데이터의 주기적 모니터링, 또는 이들의 조합에 응답하여 수신된다. 일부 실시예에서, 이미지 데이터는, 실질적으로 실시간으로 사용자 디바이스에 의해 포착되는 이미지 또는 비디오(예를 들어, 스마트 폰의 카메라 센서로부터의 라이브 이미지 피드)를 나타낸다. 다른 실시예에서, 이미지 데이터는, 과거의 시간으로부터의, 사용자 디바이스 또는 다른 디바이스에 의해 포착되어 사용자 디바이스에 저장된 이미지를 나타낸다(예를 들어, 사용자 디바이스 상에 저장된 또는 소셜 네트워킹 서비스로부터 다운로드된 스틸 이미지 또는 비디오). 이미지 데이터가 비디오 이미지 데이터를 포함하는 실시예에서, 맞춤형 패턴 시스템(160)은 비디오의 개개의 프레임들 또는 비디오의 복수의 프레임들의 조합을 분석하여 광학 바코드를 검출 및 디코딩할 수 있다. 이미지 데이터의 일부는, 특정한 기능 패턴(예를 들어, 파인더 패턴 또는 정렬 패턴)에 대해 맞춤형 그래픽, 맞춤형 심볼 또는 특정한 그래픽을 채용하는 광학 바코드를 나타내는 데이터를 포함할 수 있다.In operation 510, the communication module 210 receives image data of an image from the user device. For example, the communication module 210 receives image data from an optical sensor (e.g., a camera sensor) of the user's smartphone. In various embodiments, image data from a user device is received in response to user-initiated image capture, periodic monitoring of image data detected by an optical sensor of a user device, or a combination thereof. In some embodiments, the image data represents an image or video (e.g., a live image feed from a camera sensor of a smartphone) that is captured by the user device in substantially real time. In another embodiment, the image data represents an image captured by a user device or other device from a past time and stored on the user device (e.g., a still image stored on a user device or downloaded from a social networking service Or video). In embodiments where the image data includes video image data, the custom pattern system 160 may analyze individual frames of video or a combination of multiple frames of video to detect and decode the optical bar code. A portion of the image data may include data representing an optical barcode employing custom graphics, custom symbols, or specific graphics for a particular functional pattern (e.g., a finder pattern or an alignment pattern).

일부 시나리오에서, 이미지 데이터는, 광학 바코드에 관련된 데이터와 함께 이질적인 또는 관련없는 데이터를 포함한다(예를 들어, 광학 바코드의 이미지는 광학 바코드를 디코딩하는 것과 관련이 없는 배경을 포함한다). 특정한 예에서, 사용자 디바이스의 광학 센서는 특정한 광학 바코드를 포함하는 영화 포스터의 이미지를 포착한다. 영화 포스터의 이미지는, 특정한 광학 바코드와 함께, 그 특정한 광학 바코드를 둘러싸는 관련없는 부분들, 즉, 영화 포스터 또는 배경을 포함할 수 있다.In some scenarios, the image data includes heterogeneous or irrelevant data along with data related to the optical bar code (e.g., the image of the optical bar code includes a background unrelated to decoding the optical bar code). In a particular example, the optical sensor of the user device captures an image of a movie poster that includes a particular optical bar code. An image of a movie poster may include, in conjunction with a particular optical bar code, irrelevant portions surrounding the particular optical bar code, i. E., A movie poster or background.

동작 520에서, 파인더 모듈(230)은 이미지 데이터로부터 이미지의 후보 형상 피쳐 또는 후보 특성을 추출한다. 후보 형상 피쳐는 맞춤형 그래픽의 식별을 나타낼 수 있다(예를 들어, 맞춤형 그래픽을 나타내는 소정의 특색 또는 특성을 포함한다). 예를 들어, 파인더 모듈(230)은 엣지 검출 기술 또는 다른 이미지 처리 기술을 수행하여, 이미지의 윤곽선 또는 색상이나 음영의 국부적인 집중 등의 형상 피쳐를 식별한다. 일부 실시예에서, 파인더 모듈(230)은 이미지 데이터로부터 복수의 후보 형상 피쳐를 추출한다. 일부 실시예에서, 후보 형상 피쳐는 이미지의 경계에 관한 후보 형상 피쳐의 위치, 이미지에 관한 후보 형상 피쳐의 밝기, 후보 형상 피쳐의 평균 색상 등의 다양한 형상 피쳐 데이터를 포함한다.At operation 520, the finder module 230 extracts a candidate feature or candidate feature of the image from the image data. The candidate shape features may represent an identification of the custom graphic (e.g., including any feature or characteristic that represents a custom graphic). For example, the finder module 230 performs edge detection techniques or other image processing techniques to identify feature features such as contours of the image or local concentration of hue or shading. In some embodiments, the finder module 230 extracts a plurality of candidate shape features from the image data. In some embodiments, the candidate shape features include various shape feature data such as the position of the candidate shape feature relative to the boundaries of the image, the brightness of the candidate shape feature with respect to the image, and the average color of the candidate shape feature.

추가의 예시적인 실시예에서, 파인더 모듈(230)은 이미지의 저해상도 사본을 생성한다. 파인더 모듈(230)은, 블러(blur)(예를 들어, 가우시안 블러 함수 또는 다른 블러 함수) 및 임계화 등의, 이미지의 저해상도 복사본에 대한 다양한 이미지 처리를 수행하여 수정된 저해상도 이미지를 생성할 수 있다. 임계화 이미지 처리는, (예를 들어, 임계 또는 임계 범위에 의해 결정된) 백색 및 더 어두운 색상에 대한 이미지의 저해상도 사본의 (예를 들어, 임계 또는 임계 범위에 의해 결정된) 더 밝은 색상을 검정 색상으로 조절하는 단계를 포함할 수 있다. 그 다음, 파인더 모듈(230)은 수정된 저해상도 이미지로부터 후보 형상 피쳐를 추출하여 이미지 내의 맞춤형 그래픽의 검출을 향상시키고 이미지 내의 맞춤형 그래픽을 식별하는 계산 효율을 향상시킬 수 있다.In a further exemplary embodiment, the finder module 230 generates a low-resolution copy of the image. The finder module 230 may perform various image processing on a low resolution copy of the image, such as blur (e.g., a Gaussian Blur function or other Blur function) and thresholding, to produce a modified low resolution image have. Thresholding image processing may be performed by applying a lighter color (determined, for example, by a critical or critical range) of low resolution copies of the image for white and darker colors (e.g., determined by a critical or critical range) . ≪ / RTI > The finder module 230 can then extract candidate feature features from the modified low resolution images to improve the detection of custom graphics within the image and improve the computational efficiency of identifying custom graphics within the image.

역시 추가의 예시적인 실시예에서, 파인더 모듈(230)은 이미지의 일부의 고해상도 사본을 생성한다. 예를 들어, 파인더 모듈(230)은 추출된 후보 형상 피쳐에 대응하는 이미지의 특정한 부분의 고해상도 사본을 생성할 수 있다. 파인더 모듈(230), 정렬 모듈(240) 또는 디코더 모듈(250)은, 검출, 정렬, 및 디코딩 결과를 개선하기 위해 후술되는 바와 같이 후속 분석을 위해 고해상도 사본을 이용할 수 있다.In yet a further exemplary embodiment, the finder module 230 creates a high-resolution copy of a portion of the image. For example, the finder module 230 may generate a high-resolution copy of a particular portion of the image corresponding to the extracted candidate shape feature. The finder module 230, the alignment module 240 or the decoder module 250 may use high resolution copies for subsequent analysis as described below to improve detection, alignment, and decoding results.

동작 530에서, 파인더 모듈(230)은 후보 형상 피쳐가 하나 이상의 형상 피쳐 기준 또는 규칙을 만족한다고 결정한다. 예를 들어, 특정한 형상 피쳐가 윤곽선이라면, 파인더 모듈(230)은 윤곽선이 이미지의 일부를 둘러싸는 폐곡선인지를 결정할 수 있다. 일부 실시예와 일치하여, 형상 피쳐 규칙은 무관하거나 이질적인 피쳐를 필터링 제거한다. 특정한 형상 피쳐 규칙은 다양한 목적에 관한 것이거나 다양한 목적을 의도로 한다. 예를 들어, 특정한 형상 피쳐 규칙은 맞춤형 그래픽일 확률이 낮은 후보 형상 피쳐를 필터링 제거하도록 의도될 수 있다. 이 예에서, 특정한 형상 피쳐 규칙은 맞춤형 그래픽 특유일 수 있다. 다른 예들에서, 일부 형상 피쳐 규칙들은, 광학 바코드와 연관될 것 같지 않은 후보 형상 피쳐들을 필터링 제거하도록 의도될 수 있다. 이들 예에서, 형상 피쳐 규칙은 반드시 맞춤형 그래픽 특유일 필요는 없다.At operation 530, the finder module 230 determines that the candidate shape feature meets one or more shape feature criteria or rules. For example, if a particular feature feature is an outline, the finder module 230 can determine if the outline is a closed curve that surrounds a portion of the image. Consistent with some embodiments, the feature feature rules filter out irrelevant or heterogeneous features. Specific shape feature rules are for various purposes or for various purposes. For example, a particular shape feature rule may be intended to filter out candidate feature features that are less likely to be custom graphics. In this example, the specific shape feature rules may be specific to the custom graphics. In other examples, some shape feature rules may be intended to filter out candidate shape features that are not likely to be associated with the optical bar code. In these examples, the shape feature rules do not necessarily have to be specific to the custom graphics.

동작 540에서, 형상 피쳐 규칙을 만족하는 후보 형상 피쳐에 응답하여, 파인더 모듈(230)은, 후보 형상 피쳐를 맞춤형 그래픽 또는 맞춤형 심볼의 기준 형상 피쳐와 비교함으로써 이미지 내의 맞춤형 그래픽 또는 맞춤형 심볼을 식별한다. 예를 들어, 파인더 모듈(230)은 후보 형상 피쳐의 면적 또는 크기를 기준 형상 피쳐의 기준 면적 또는 크기와 비교할 수 있다. 이 예에서, 파인더 모듈(230)은 후보 형상 피쳐와 기준 형상 피쳐 사이의 일치 또는 준일치(예를 들어, 임계값보다 높은 백분율 일치)에 기초하여 맞춤형 그래픽을 식별한다. 이러한 방식으로, 파인더 모듈(230)은, 맞춤형 그래픽 또는 맞춤형 그래픽의 적어도 일부를 파인더 패턴으로서 이용하여 이미지의 일부 내의 광학 바코드의 존재를 식별한다.In operation 540, in response to a candidate shape feature that satisfies the shape feature rule, the finder module 230 identifies a customized graphic or custom symbol in the image by comparing the candidate shape feature to a custom feature of the custom or custom symbol . For example, the finder module 230 may compare the area or size of the candidate feature with the reference area or size of the reference feature. In this example, the finder module 230 identifies a custom graphic based on a match or a sub match (e.g., a percentage match above the threshold) between the candidate feature and the reference feature. In this manner, the finder module 230 identifies the presence of an optical bar code in a portion of the image using at least a portion of the custom graphic or custom graphic as a finder pattern.

일부 실시예에서, 파인더 모듈(230)은 이미지 데이터로부터 복수의 후보 형상 피쳐를 추출한다. 이들 실시예에서, 파인더 모듈(230)은 각각의 후보 형상 피쳐를 채점하고, 각각의 점수에 따라 복수의 후보 형상 피쳐를 순위화한다. 예를 들어, 파인더 모듈(230)은, 각각의 후보 형상 피쳐가 만족하는 형상 피쳐 규칙의 카운트 또는 가중 카운트에 기초하여, 각각의 후보 형상 피쳐에 대한 형상 피쳐 점수를 결정한다. 파인더 모듈(230)은, 최고 점수 후보 형상 피쳐에서 시작하여 순위화된 후보 형상 피쳐들을 반복하고, 후보 형상 피쳐가 맞춤형 그래픽이라고 결정하기 위해 추가 분석(예를 들어, 후보 형상 피쳐를 기준 형상 피쳐와 비교)을 수행할 수 있다.In some embodiments, the finder module 230 extracts a plurality of candidate shape features from the image data. In these embodiments, the finder module 230 scales each candidate shape feature and ranks the plurality of candidate shape features according to each score. For example, the finder module 230 determines a shape feature score for each candidate shape feature based on a count or a weighted count of shape feature rules that each candidate shape feature satisfies. The finder module 230 repeats the ranked candidate shape features, starting from the highest score candidate shape feature, and performs additional analysis (e.g., determining the candidate shape feature as a reference shape feature Comparison) can be performed.

일부 실시예에서, 기준 형상 피쳐는 미리결정되고, 다른 실시예에서는, 기준 형상 피쳐가 동적으로 결정된다. 예를 들어, 파인더 모듈(230)은 맞춤형 그래픽의 기준 이미지를 분석함으로써 기준 형상 피쳐를 동적으로 결정할 수 있다. 예를 들어, 파인더 모듈(230)은, 기준 이미지의 특정한 피쳐 또는 특성에 대한 기준 면적 값을 계산하는 것 등의 기준 이미지에 관한 이미지 데이터를 분석하기 위한 분석 기술과 유사한 분석 기술을 수행할 수 있다. 이들 실시예에서, 기준 형상 피쳐를 동적으로 결정하는 파인더 모듈(230)은 광학 바코드 내의 기능 패턴으로서 특정한 맞춤형 그래픽의 동적 이용을 허용한다. 예를 들어, 맞춤형 패턴 시스템(160)은, 방법(500)이 수행될 때 기준 이미지를 나타내는 데이터 또는 기준 피쳐를 나타내는 데이터를 제공받을(예를 들어, 통신 모듈(210)에서 수신될) 수 있다. 이러한 방식으로, 맞춤형 기능 패턴은 방법(500)을 수행하기 전에 반드시 고정될 필요는 없다.In some embodiments, the reference shape feature is predetermined, and in another embodiment, the reference shape feature is determined dynamically. For example, the finder module 230 may dynamically determine a reference feature feature by analyzing the reference image of the custom graphics. For example, the finder module 230 may perform an analysis technique similar to an analysis technique for analyzing image data on a reference image, such as calculating a reference area value for a particular feature or characteristic of a reference image . In these embodiments, the finder module 230, which dynamically determines a reference shape feature, allows dynamic use of a particular customized graphic as a functional pattern in the optical bar code. For example, the custom pattern system 160 may be provided (e.g., to be received at the communication module 210) with data indicative of a reference image or data indicative of a reference feature when the method 500 is performed . In this manner, the customized function pattern does not necessarily have to be fixed before performing method 500.

추가의 예시적인 실시예에서, 파인더 모듈(230)은 (예를 들어, 복수의 버전 또는 상이한 맞춤형 그래픽들이 기능 패턴으로서 이용되는 경우) 이미지의 이미지 데이터에서 복수의 맞춤형 그래픽을 검색한다. 특정한 예에서, 맞춤형 그래픽은 제1 회사 로고를 포함할 수 있고, 그 회사는 로고를 제2 회사 로고로 변경할 수 있다. 맞춤형 패턴 시스템(160)은 제1 회사 로고를 파인더 패턴으로서 이용하고 제2 회사 로고를 파인더 패턴으로서 이용하며 맞춤형 패턴 시스템(160)은 방법(500)을 수행할 때 각각의 로고를 검색할 수 있다.In a further exemplary embodiment, the finder module 230 retrieves a plurality of custom graphics from the image data of the image (e.g., when multiple versions or different custom graphics are used as a function pattern). In a particular example, the customized graphic may include a first company logo, and the company may change the logo to a second company logo. The custom pattern system 160 may utilize the first company logo as a finder pattern and the second company logo as a finder pattern and the custom pattern system 160 may retrieve the respective logo when performing the method 500 .

추가의 예시적인 실시예에서, 파인더 모듈(230)은, 이미지 데이터로부터 추출된 다른 후보 형상 피쳐들과 연계하여 이미지 내의 맞춤형 그래픽을 식별한다. 예를 들어, 파인더 모듈(230)은, 맞춤형 그래픽(예를 들어, 로고)과 맞춤형 그래픽을 둘러싸고 있는 외곽 박스(예컨대, 외곽 박스(325)) 양쪽 모두를 검색할 수 있다. 이들 실시예에서, 파인더 모듈(230)은, 맞춤형 그래픽과, 이미지 데이터로부터 추출된 하나 이상의 추가 후보 형상 피쳐의 조합을 식별한다.In a further exemplary embodiment, the finder module 230 identifies custom graphics within the image in conjunction with other candidate shape features extracted from the image data. For example, the finder module 230 may search both a custom graphic (e.g., a logo) and an outer box (e.g., outer box 325) that surrounds the custom graphic. In these embodiments, the finder module 230 identifies a combination of custom graphics and one or more additional candidate shape features extracted from the image data.

동작 550에서, 맞춤형 그래픽의 식별에 응답하여, 정렬 모듈(240)은, 이미지 데이터로부터 이미지 내의 맞춤형 그래픽 또는 맞춤형 심볼의 공간적 속성, 기하학 속성, 또는 공간적 특성을 추출한다. 예를 들어, 정렬 모듈(240)은 이미지 데이터로부터 맞춤형 그래픽의 위치, 스케일 또는 배향을 추출한다. 다양한 예시적인 실시예에서, 공간적 속성은 이미지 내의 맞춤형 그래픽의 배향을 나타낸다. 정렬 모듈(240) 또는 디코더 모듈(250)은 공간적 속성을 이용하여 광학 바코드의 디코딩을 가능하게 할 수 있다.In operation 550, in response to identifying the custom graphics, the alignment module 240 extracts spatial, geometric, or spatial characteristics of the customized graphics or custom symbols in the image from the image data. For example, the alignment module 240 extracts the position, scale, or orientation of the custom graphics from the image data. In various exemplary embodiments, the spatial attribute represents the orientation of the customized graphics in the image. Alignment module 240 or decoder module 250 may enable decoding of optical bar codes using spatial attributes.

추가의 실시예에서, 정렬 모듈(240)은, 이미지의 이미지 데이터로부터 추출된 또 다른 후보 형상 피쳐의 공간적 속성, 기하학적 속성 또는 공간적 특성을 추출한다. 예를 들어, 정렬 모듈(240)은, 데이터를 인코딩하는 마킹들과 맞춤형 그래픽을 둘러싸는 외곽 박스(예를 들어, 도 3a의 외곽 박스(325))의 공간적 속성을 추출한다. 후속되는 논의 전체를 통해, 정렬 모듈(240) 및 디코더 모듈(250)은 맞춤형 그래픽의 공간적 속성과 동일하거나 유사한 방식으로 외곽 박스의 공간적 속성을 이용하여 디코딩을 가능하게 하는데 이용되는 광학 바코드의 정렬을 결정할 수 있다는 점에 주목할 것이다. 예를 들어, 정렬 모듈(240) 또는 디코더 모듈(250)은, 외곽 박스의 공간적 속성을 이용하여 이미지 내에 인코딩된 데이터를 디코딩하는데 이용되는 이미지의 변환된 이미지를 생성할 수 있다.In a further embodiment, the alignment module 240 extracts the spatial properties, geometric properties, or spatial properties of another candidate shape feature extracted from the image data of the image. For example, the sorting module 240 extracts the spatial attributes of the outer box (e.g., outer box 325 of FIG. 3A) surrounding the markings and the custom graphics to encode the data. Throughout the following discussion, the alignment module 240 and the decoder module 250 can be used to determine the alignment of the optical barcode used to enable decoding using the spatial properties of the outline box in the same or similar manner as the spatial properties of the customized graphics It will be noted that you can decide. For example, the alignment module 240 or the decoder module 250 may generate the transformed image of the image used to decode the data encoded in the image using the spatial property of the outer box.

동작 560에서, 디코더 모듈(250)은 이미지 내의 맞춤형 그래픽의 공간적 속성을 이용하여 이미지 데이터로부터 이미지의 일부 내에 인코딩된 데이터를 디코딩한다. 예를 들어, 디코더 모듈(250)은 공간적 속성(예를 들어, 디-스큐, 회전, 스케일, 또는 또 다른 타입의 이미지 변환)을 이용하여 이미지 변환을 수행하여 이미지의 일부에 인코딩된 데이터의 검출능 또는 신뢰성을 향상시킬 수 있다. 한 실시예에서, 디코더 모듈(250)은, 이미지에 포함된 데이터를 나타내는 마킹(예컨대, 도트, 사각형 또는 다른 마킹)을 검출함으로써 이미지의 일부 내에 인코딩된 데이터를 디코딩한다. 이러한 방식으로, 디코더 모듈(250)은, 광학 바코드의 디코딩을 가능하게 하는 정렬 패턴으로서 맞춤형 그래픽 또는 맞춤형 그래픽의 적어도 일부를 이용한다. 다양한 실시예에서, 디코더 모듈(250)은, 이미지 내에 인코딩된 데이터를 디코딩하기 위해 Reed-Solomon 에러 정정 방식을 채용한다. Reed-Solomon 에러 정정 방식은, 이미지 내에 인코딩된 데이터의 소정의 백분율이 파손되거나 손상되거나 부정확하게 디코딩된 상태에서 이미지 내에 인코딩된 데이터의 성공적인 디코딩을 허용한다. 추가의 실시예에서, 디코더 모듈(250)은 소량의 체크섬을 이용하여 이미지 데이터로부터 디코딩된 값이 랜덤 데이터(예를 들어, 랜덤 비트)가 아닌 실제 데이터를 포함하는 값인지를 검증한다.At operation 560, the decoder module 250 decodes the encoded data within the portion of the image from the image data using the spatial properties of the customized graphics in the image. For example, the decoder module 250 performs image transformation using spatial attributes (e.g., de-skew, rotate, scale, or another type of image transformation) to detect Performance or reliability can be improved. In one embodiment, the decoder module 250 decodes the encoded data within a portion of the image by detecting markings (e.g., dots, squares, or other markings) indicative of the data contained in the image. In this manner, the decoder module 250 utilizes at least some of the customized or customized graphics as an alignment pattern to enable decoding of the optical bar code. In various embodiments, the decoder module 250 employs a Reed-Solomon error correction scheme to decode the encoded data in the image. The Reed-Solomon error correction scheme allows successful decoding of encoded data in an image with a predetermined percentage of data encoded within the image being corrupted, corrupted, or incorrectly decoded. In a further embodiment, the decoder module 250 uses a small amount of checksum to verify that the value decoded from the image data is a value that contains real data rather than random data (e.g., random bits).

추가의 예시적인 실시예에서, 디코더 모듈(250)은 디코딩된 데이터의 소정의 결과(예를 들어, 맞춤형 패턴 시스템(160)의 관리자에 의해 지정된 바와 같이, 무효인 것으로 알려진 이미지 데이터로부터 디코딩된 데이터의 결과)를 거부한다. 예를 들어, 디코더 모듈(250)은, 디코딩된 데이터가 다른 데이터 무결성 테스트(예를 들어, 에러 정정 및 체크섬)를 통과하더라도, 모두 0, 모두 1, 또는 다른 지정된 결과를 포함하는 디코딩된 데이터를 거부할 수 있다. 예를 들어, 이것은, 맞춤형 패턴 시스템(160)이 데이터를 나타내는 임의의 연관된 마킹없이 맞춤형 그래픽을 스캔할 때 발생할 수 있다(예를 들어, 맞춤형 그래픽이 로고인 경우, 단순히 로고를 스캔하면 디코딩된 데이터에서 모두 0이 생성될 수 있고 디코더 모듈(250)에 의해 거부될 수 있다). 특정한 예에서, 도 19에서 아래에 도시된 바와 같이, 소셜 메시징 앱(1908)과 연관된 아이콘을 스캐닝하면, 모두 0인 데이터가 생성될 것이고, 디코더 모듈(250)은 그 스캔을 거부할 것이다.In a further exemplary embodiment, the decoder module 250 decodes the decoded data from image data that is known to be invalid, as specified by the administrator of the custom pattern system 160 (e.g., Of the results). For example, decoder module 250 may decode decoded data, including all 0, all ones, or other specified results, even if the decoded data passes other data integrity tests (e.g., error correction and checksum) You can refuse. For example, this may occur when the custom pattern system 160 scans a custom graphic without any associated marking representing the data (e.g., if the custom graphic is a logo, simply scanning the logo may result in the decoded data All zeros may be generated and may be rejected by the decoder module 250). In a particular example, scanning an icon associated with the social messaging application 1908, as shown below in FIG. 19, will result in data all zeros, and the decoder module 250 will reject the scan.

도 6은 맞춤형 기능 패턴을 이용하여 광학 바코드(예를 들어, 광학 바코드(406))를 식별하기 위한 추가의 예시적인 동작을 도시하는 흐름도이다. 동작 530에서, 파인더 모듈(230)은 후보 형상 피쳐가 형상 피쳐 규칙을 만족한다고 결정한다. 일부 실시예에서, 동작 530은 도 6의 동작들을 포함한다.6 is a flow chart illustrating additional exemplary operation for identifying an optical bar code (e.g., optical bar code 406) using a customized function pattern. At operation 530, the finder module 230 determines that the candidate shape feature satisfies the shape feature rule. In some embodiments, operation 530 includes the operations of FIG.

동작 610에서, 파인더 모듈(230)은 이미지 데이터로부터 후보 형상 피쳐가 폐곡선을 포함한다고 결정한다. 즉, 형상 피쳐 규칙은 경로 규칙을 포함하고, 파인더 모듈(230)은 후보 형상 피쳐가 경로 규칙을 만족한다고 결정한다. 파인더 모듈(230)은 후보 형상 피쳐가 경로 규칙을 만족하는지를 결정하기 위해 다양한 기술을 채용할 수 있다.At operation 610, the finder module 230 determines from the image data that the candidate shape feature includes a closed curve. That is, the shape feature rule includes a path rule, and the finder module 230 determines that the candidate shape feature satisfies the path rule. The finder module 230 may employ various techniques to determine if the candidate shape feature satisfies the path rule.

동작 630에서, 파인더 모듈(230)은, 후보 형상 피쳐가 특정한 지점에서 시작하여 동일한 그 특정한 지점으로 복귀하는 경로를 가져 이미지의 일부를 둘러싼다고 결정함으로써, 후보 형상 피쳐가 폐곡선인지를 결정한다. 예시적인 실시예에서, 후보 형상 피쳐가 경로 규칙을 만족하지 않으면(도 6에서 "아니오"로 표시됨), 후보 형상 피쳐의 추가 분석은 수행되지 않고, 파인더 모듈(230)은 또 다른 후보 형상 피쳐를 분석하거나 어떠한 추가의 동작도 수행하지 않는다. 대안으로서, 동작 640에서, 파인더 모듈(230)이 후보 형상 피쳐가 경로 규칙을 만족한다고 결정하면(도 6에서 "예"로 표시됨), 방법(500)의 후속 동작들이 수행된다.In operation 630, the finder module 230 determines whether the candidate shape feature is a closed curve by determining that the candidate shape feature has a path starting at a particular point and returning to that same point at the same location, surrounding the portion of the image. In the exemplary embodiment, if the candidate shape feature does not satisfy the path rule (denoted as "NO" in FIG. 6), no further analysis of the candidate shape feature is performed and the finder module 230 returns another candidate shape feature Does not analyze or perform any additional operations. Alternatively, at operation 640, if the finder module 230 determines that the candidate shape feature satisfies the path rule (indicated as "Yes" in FIG. 6), subsequent operations of the method 500 are performed.

도 6의 개념을 예시하기 위해, 도 7은 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하는 예를 나타내는 도면(700)이다. 도면(700)에서, 이미지(710)는 사용자 디바이스로부터 수신되거나 액세스되는 예시적인 이미지이다. 이미지 720는 예시적인 후보 형상 피쳐(730)들을 나타내는 예시적인 이미지이다. 예를 들어, 파인더 모듈(230)은 이미지 710에 관해 엣지 검출 이미지 처리를 수행하여 이미지 720을 도출한다. 이미지 720으로부터, 파인더 모듈(230)은 후보 형상 피쳐(730)들을 식별한다.To illustrate the concept of Fig. 6, Fig. 7 is a drawing 700 illustrating an example of identifying an optical bar code using a customized function pattern. In the drawing 700, an image 710 is an exemplary image that is received or accessed from a user device. Image 720 is an exemplary image representing exemplary candidate shape features 730. For example, the finder module 230 performs edge detection image processing on the image 710 to derive an image 720. From image 720, finder module 230 identifies candidate feature features 730.

콜아웃(740)은 후보 형상 피쳐(730)들 중의 특정한 후보 형상 피쳐를 도시한다. 콜아웃(740)은, 특정한 후보 형상 피쳐의 (점선으로 나타낸) 윤곽선(750), 경로(760), 및 특정한 후보 형상 형상의 한 지점(770)을 도시한다. 콜아웃(740)에서, 파인더 모듈(230)은, 지점(770)에서 시작하는 경로(760)가 윤곽선(750)을 따라 지점(770)으로 되돌아 갈 수 있다면 경로 규칙이 만족된다고 결정한다. 도면(700)에서, 콜아웃(740)에 도시된 특정한 후보 형상 피쳐는, 경로(760)가 윤곽선(750)을 따라 지점(770)으로 돌아올 수 있기 때문에 경로 규칙을 만족한다.Callout 740 illustrates a particular candidate shape feature among the candidate shape features 730. Callout 740 illustrates a contour 750, path 760, and a point 770 of a particular candidate shape feature (shown in dotted lines) of a particular candidate shape feature. At callout 740, the finder module 230 determines that the path rule is satisfied if path 760 starting at point 770 can return to point 770 along contour 750. In figure 700, the particular candidate shape feature shown in callout 740 satisfies the path rule because path 760 can return to point 770 along contour 750.

도 8은 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다. 동작 530에서, 파인더 모듈(230)은 후보 형상 피쳐가 형상 피쳐 규칙을 만족한다고 결정한다. 일부 실시예에서, 동작 530은 도 8의 동작들을 포함한다.Fig. 8 is a flow diagram illustrating a further exemplary operation for identifying an optical bar code using a customized function pattern. At operation 530, the finder module 230 determines that the candidate shape feature satisfies the shape feature rule. In some embodiments, operation 530 includes the operations of FIG.

동작 810에서, 파인더 모듈(230)은 후보 형상 피쳐의 면적 값 또는 크기 근사를 계산한다. 예를 들어, 파인더 모듈(230)은, 다각형(예를 들어, 정사각형, 직사각형 또는 사변형) 또는 비다각형 형상(예를 들어, 타원) 등의 프록시 형상을 이용하여 후보 형상 피쳐의 형상을 근사화한다. 파인더 모듈(230)은, 프록시 형상이 후보 형상 피쳐의 영역을 대표하도록 후보 형상 피쳐의 외측 엣지 또는 외측 경계에 프록시 형상을 맞추거나 거의 맞춘다. 후속해서, 파인더 모듈(230)은 프록시 형상의 면적 값을 계산하여 후보 형상 피쳐의 면적 값 또는 크기 근사를 결정한다. 일부 실시예에서, 파인더 모듈(230)은 후보 형상 피쳐가 형상에 있어서 복잡할 수 있는 상황에서 후보 형상 피쳐의 계산적으로 값 비싼 면적 계산을 피하기 위해 이러한 기술(예를 들어, 다각형 면적 근사화)을 이용한다(예를 들어, 불균일하거나 불규칙한 형상의 피쳐에 대한 면적 계산은 대개 계산적으로 더 비싸다). 일부 실시예에서, 면적 값을 결정하기 위해 픽셀 기반 카운팅 등의 다른 기술들이 패용될 수 있다.At operation 810, the finder module 230 calculates an area value or magnitude approximation of the candidate shape feature. For example, the finder module 230 approximates the shape of a candidate shape feature using a proxy shape such as a polygonal (e.g., square, rectangular, or quadrilateral) or non-polygonal shape (e.g., ellipse). The finder module 230 aligns or approximates the proxy shape to the outer edge or outer boundary of the candidate shape feature so that the proxy shape represents the area of the candidate shape feature. Subsequently, the finder module 230 calculates the area value of the proxy shape to determine the area value or magnitude approximation of the candidate shape feature. In some embodiments, the finder module 230 uses this technique (e.g., polygon area approximation) to avoid computationally expensive area calculations of candidate shape features in situations where the candidate shape features may be complex in shape (For example, area calculations for features with irregular or irregular shapes are usually computationally more expensive). In some embodiments, other techniques, such as pixel based counting, can be exploited to determine area values.

동작 820에서, 파인더 모듈(230)은 후보 형상 피쳐의 면적 점수 또는 크기 점수를 결정한다. 파인더 모듈(230)은 후보 형상 피쳐의 면적 값을 기준 면적 값과 비교함으로써 면적 점수를 결정한다. 일부 실시예에서, 기준 면적 값은 맞춤형 그래픽의 기준 이미지에 맞추어진 대응하는 프록시 형상의 면적 값(예를 들어, 정면 관점에서 유령 로고에 맞추어진 프록시 형상의 면적 값)을 포함한다. 다른 실시예에서, 기준 면적 값은 맞춤형 그래픽의 면적 값(예를 들어, 유령 로고의 면적 값)을 포함한다. 파인더 모듈(230)은, 예를 들어, 후보 형상 피쳐 면적 값과 기준 면적 값 사이의 일치 백분률을 결정함으로써 면적 점수를 계산한다. 파인더 모듈(230)은 면적 점수를 계산하기 위해 다양한 다른 방식 및 기술을 채용할 수 있다.At operation 820, the finder module 230 determines the area score or size score of the candidate shape feature. The finder module 230 determines the area score by comparing the area value of the candidate shape feature with the reference area value. In some embodiments, the reference area value includes an area value of the corresponding proxy shape (e.g., an area value of the proxy shape aligned with the ghost logo in front view) tailored to the reference image of the custom graphics. In another embodiment, the reference area value includes an area value of the custom graphic (e.g., an area value of the ghost logo). The finder module 230 calculates the area score, for example, by determining a matching percentage between the candidate shape feature area value and the reference area value. The finder module 230 may employ various other schemes and techniques to calculate the area score.

동작 830에서, 파인더 모듈(230)은 면적 점수가 임계값을 초과하는지를 결정한다. 임계값은 미리정의되거나 동적으로 결정(예를 들어, 스캔들의 이동 이력 평균(rolling historical average)에 기초하여 통계적으로 결정)될 수 있다.At operation 830, the finder module 230 determines if the area score exceeds a threshold. The threshold may be predefined or dynamically determined (e.g., statistically determined based on the rolling historical average of the scans).

동작 840에서, 임계값을 초과하는 면적 점수(도 8에서 "예"로 표시됨)에 기초하여, 파인더 모듈(230)은 후보 형상 피쳐가 면적 규칙을 만족한다고 결정하고 후속 동작으로 진행한다. 또 다른 예시적인 실시예에서, 파인더 모듈(230)은, 면적 점수를, 면적 규칙을 만족하는 (예를 들어, 특정한 값보다 크고 특정한 값보다 작은) 면적 범위와 비교한다. 면적 점수가 임계값을 초과하지 않으면(도 8에서 "아니오"로 표시됨), 예시적인 실시예에 따라, 파인더 모듈(230)은 또 다른 후보 형상 피쳐를 분석하거나 어떠한 추가 동작도 수행하지 않는다. 일부 예시적인 실시예에서, 파인더 모듈(230)은 (예를 들어, 맞춤형 그래픽이 아닐 가능성이 높은 후보 형상 피쳐를 제거하거나 스킵하기 위해) 후보 형상 피쳐가 형상 피쳐 규칙을 만족하는지의 결정을 필터로서 이용하여 이미지 내의 맞춤형 그래픽을 식별하는 프로세스에서 추가로 분석될 후보 형상 피쳐들을 식별한다.In operation 840, based on the area score exceeding the threshold (denoted as "Yes" in FIG. 8), the finder module 230 determines that the candidate shape feature satisfies the area rule and proceeds to a subsequent operation. In another exemplary embodiment, the finder module 230 compares the area score with an area range that meets the area rule (e.g., greater than a particular value and less than a particular value). If the area score does not exceed the threshold (denoted as "NO" in FIG. 8), in accordance with the exemplary embodiment, the finder module 230 does not analyze another candidate shape feature or perform any additional operations. In some exemplary embodiments, the finder module 230 may use the determination of whether the candidate shape feature satisfies the shape feature rules (e.g., to remove or skip a candidate shape feature that is not likely to be a customized graphic) To identify candidate shape features to be further analyzed in the process of identifying a customized graphic in the image.

도 8의 개념을 더 예시하기 위해, 도 9는 맞춤형 기능 패턴을 이용하여 광학 바코드를 식별하는 예를 나타내는 도면(900)이다. 도면(900)에서, 이미지(902)는 사용자 디바이스로부터 수신되는 예시적인 이미지이다. 콜아웃(904)은 이미지(902)의 공간적 배향을 도시한다. 이 예에서, 이미지(902)가 표시되고, 정면 우측 관점에서 본 것이다. 이미지(902)는 광학 바코드(906)를 포함한다. 이 예에서, 광학 바코드(906)는 맞춤형 그래픽을 기능 패턴으로서 채용한다.To further illustrate the concept of FIG. 8, FIG. 9 is a diagram 900 illustrating an example of identifying an optical bar code using a customized function pattern. In the drawing 900, an image 902 is an exemplary image received from a user device. Callout 904 illustrates the spatial orientation of image 902. In this example, an image 902 is displayed and viewed from the front right view. The image 902 includes an optical bar code 906. In this example, the optical bar code 906 employs a custom graphic as a functional pattern.

콜아웃(908)은, 맞춤형 그래픽을 식별하기 위해 파인더 모듈(230)에 의해 분석되는 후보 형상 피쳐를 포함하는 이미지(902)의 확대 부분을 도시한다. 콜아웃(908)에서, 다각형(910)(예를 들어, 사변형)이 후보 형상 피쳐의 경계에 맞추어져 있는 것으로 도시되어 있다. 면적 값(912)은 다각형(910)의 면적이다.The callout 908 shows an enlarged portion of the image 902 that includes candidate feature features that are analyzed by the finder module 230 to identify the customized graphics. At the callout 908, a polygon 910 (e.g., a quadrangle) is shown aligned to the boundary of the candidate shape feature. The area value 912 is the area of the polygon 910.

콜아웃(914)은 맞춤형 그래픽의 기준 이미지를 보여준다. 콜아웃(916)은 기준 이미지의 공간적 배향을 보여준다. 이 예에서, 기준 이미지는 정면 관점에서 보여진 것이다. 다각형(918)은 기준 이미지의 경계에 맞추어진 것으로 도시되어 있다. 기준 면적 값(920)은 다각형(918)의 면적이다. 도 9는 사변형으로서의 다각형(910 및 918)을 도시하고 있지만, 파인더 모듈(230)은 정사각형 또는 후보 형상 피쳐의 윤곽선을 따르거나 추적하는 형상 등의 다른 형상(예를 들어, 후보 형상 피쳐의 윤곽 점들을 따르는 n변 다각형 또는 매끄러운 맞는 형상)을 채용할 수 있다.The callout 914 shows the reference image of the custom graphic. Callout 916 shows the spatial orientation of the reference image. In this example, the reference image is shown in front view. The polygon 918 is shown aligned to the boundary of the reference image. The reference area value 920 is the area of the polygon 918. Although FIG. 9 illustrates polygons 910 and 918 as quadrants, the finder module 230 may be configured to include other shapes such as shapes that follow or track the contours of square or candidate shape features (e.g., contour points of candidate shape features Lt; / RTI > polygonal or smoothly conforming shape).

파인더 모듈(230)은 면적 값(912)과 기준 면적 값(920)을 비교하여, 후보 형상 피쳐가 면적 규칙을 만족하는지를 결정한다. 이미지(902)의 음표들 중 하나 등의, 이미지(902)의 또 다른 후보 형상 피쳐는, 기준 면적 값과 유사한 면적 값을 갖지 않을 것이고, 따라서 영역 규칙을 만족하지 못할 것이다. 이러한 방식으로, 파인더 모듈(230)은 맞춤형 그래픽으로서 식별될 것 같지 않은 소정의 후보 형상 피쳐를 신속하게 제거하거나 스킵할 수 있다.The finder module 230 compares the area value 912 with the reference area value 920 to determine if the candidate shape feature satisfies the area rule. Another candidate shape feature of the image 902, such as one of the notes of the image 902, will not have an area value similar to the reference area value and thus will not satisfy the area rule. In this manner, the finder module 230 can quickly remove or skip certain candidate feature features that are not likely to be identified as custom graphics.

도 10은 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다. 동작 540에서, 파인더 모듈(230)은 후보 형상 피쳐를 맞춤형 그래픽의 기준 형상 피쳐와 비교함으로써 이미지 내의 맞춤형 그래픽을 식별한다. 동작 540에 후속하여, 도 10의 동작들은 일부 예시적인 실시예에서 수행된다.10 is a flow diagram illustrating a further exemplary operation for decoding an optical bar code using a customized function pattern. At operation 540, the finder module 230 identifies the custom graphics within the image by comparing the candidate shape feature with a reference shape feature of the custom graphics. Following operation 540, the operations of FIG. 10 are performed in some exemplary embodiments.

동작 1010에서, 정렬 모듈(240)은 이미지 데이터로부터 맞춤형 그래픽의 고유 피쳐를 추출하며, 여기서, 고유 피쳐는 맞춤형 그래픽의 정렬을 나타낸다(예를 들어, 맞춤형 그래픽의 배향을 결정하는데 이용될 수 있는 맞춤형 그래픽의 특정한 비대칭성). 예를 들어, 고유 피쳐는, 맞춤형 그래픽의 고유 지점, 고유 곡선, 특정한 비대칭성, 특정한 불균일성, 또는 맞춤형 그래픽의 또 다른 특성을 포함할 수 있다.At operation 1010, the alignment module 240 extracts the intrinsic features of the custom graphics from the image data, where the intrinsic features represent the alignment of the custom graphics (e.g., customizable Specific asymmetry of graphics). For example, the intrinsic feature may include an intrinsic point of the custom graphic, a characteristic curve, a specific asymmetry, a specific non-uniformity, or another characteristic of the custom graphic.

동작 1020에서, 정렬 모듈(240)은, 고유 피쳐를 맞춤형 그래픽의 기준 고유 피쳐와 비교함으로써 이미지에서 맞춤형 그래픽의 배향을 결정한다. 예를 들어, 정렬 모듈(240)은 맞춤형 그래픽의 추출된 고유 피쳐를 기준 고유 피쳐에 맵핑하여 고유 피쳐들 사이의 공간적 차이를 결정한다. 이러한 방식으로, 정렬 모듈(240)은, 결정된 공간적 차이에 기초하여 맞춤형 그래픽의 기준 이미지와 비교하여 맞춤형 그래픽의 정렬을 결정할 수 있다.In operation 1020, the alignment module 240 determines the orientation of the custom graphics in the image by comparing the intrinsic features to the reference intrinsic features of the custom graphics. For example, the alignment module 240 maps the extracted intrinsic features of the custom graphics to a reference intrinsic feature to determine spatial differences between intrinsic features. In this manner, the alignment module 240 can determine the alignment of the customized graphics by comparing it with the reference image of the customized graphic based on the determined spatial difference.

동작 1030에서, 정렬 모듈(240)은 맞춤형 그래픽의 배향에 따라 이미지를 변환함으로써 변환된 이미지를 생성한다. 예를 들어, 정렬 모듈(240)은 이미지 내의 데이터의 더욱 정확한 디코딩을 허용하기 위해 이미지를 회전, 디스큐, 스케일링 또는 기타의 방식으로 공간적으로 변환할 수 있다.In operation 1030, the alignment module 240 generates the transformed image by transforming the image according to the orientation of the custom graphics. For example, the alignment module 240 may rotate, deskew, scale, or otherwise spatially transform an image to allow more accurate decoding of the data in the image.

동작 1040에서, 디코더 모듈(250)은 이미지 내의 맞춤형 그래픽의 배향 및 위치를 이용하여 이미지 내에 인코딩된 데이터를 디코딩한다. 예를 들어, 디코더 모듈(250)은 변환된 이미지로부터 이미지 내에 인코딩된 날짜를 디코딩한다. 특정한 시나리오에서, 이미지는 정면도로 변환되어 이미지 내에 인코딩된 데이터를 나타내는 이미지 내의 마크의 가시성과 균일성을 향상시킨다.At operation 1040, the decoder module 250 decodes the encoded data within the image using the orientation and position of the custom graphics within the image. For example, the decoder module 250 decodes the encoded date in the image from the transformed image. In certain scenarios, an image is converted to a front view to improve the visibility and uniformity of marks in the image that represent the data encoded within the image.

도 10의 개시내용의 이해를 보조하기 위해, 도 11은 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하는 예를 나타내는 도면(1100)이다. 도면(1100)에서, 전술된 도 9와 유사하게, 이미지(1102)는 사용자 디바이스로부터 수신되는 예시적인 이미지이다. 이 예에서, 이미지(1102)가 표시되고, 정면 우측 관점에서 본 것이다. 이미지(1102)는 광학 바코드(1106)를 포함한다. 이 예에서, 광학 바코드(1106)는 맞춤형 그래픽을 기능 패턴으로서 채용한다.To assist in understanding the teachings of FIG. 10, FIG. 11 is a drawing 1100 illustrating an example of decoding an optical bar code using a customized function pattern. In FIG. 1100, similar to FIG. 9 described above, image 1102 is an exemplary image received from a user device. In this example, an image 1102 is displayed and viewed from the front right view. The image 1102 includes an optical bar code 1106. In this example, the optical bar code 1106 employs a custom graphic as a functional pattern.

콜아웃(1108)은 정렬 모듈(240)에 의해 분석되는 후보 형상 피쳐를 포함하는 이미지(1102)의 확대된 부분을 도시한다. 콜아웃(1110)은 후보 형상 피쳐의 고유 피쳐를 보여주는 콜아웃(1108)의 확대된 부분을 보여준다.Callout 1108 shows an enlarged portion of image 1102 that includes candidate shape features that are analyzed by alignment module 240. The callout 1110 shows an enlarged portion of the callout 1108 showing the unique features of the candidate shape feature.

콜아웃(1112)은 맞춤형 그래픽의 기준 이미지를 보여준다. 콜아웃(1114)은 기준 이미지의 공간적 배향을 보여준다. 이 예에서, 기준 이미지는 정면 관점에서 보여진 것이다. 콜아웃(1116)은 기준 이미지의 기준 고유 피쳐를 보여주는 콜아웃(1112)의 확대된 부분을 보여준다.Callout 1112 shows a custom image of the reference image. Callout 1114 shows the spatial orientation of the reference image. In this example, the reference image is shown in front view. Callout 1116 shows an enlarged portion of callout 1112 showing the reference intrinsic feature of the reference image.

정렬 모듈(240)은 고유 피쳐 및 기준 고유 피쳐를 비교하여, 배향, 스케일, 또는 위치를 포함하는 정렬을 결정한다. 예를 들어, 맞춤형 그래픽을 포함하는 이미지가 정면에서 볼 때의 이미지라면, 이미지 내의 맞춤형 그래픽의 고유 피쳐는 기준 고유 피쳐와 일치해야 한다. 정렬 모듈(240)은 고유 피쳐와 기준 고유 피쳐 사이의 불일치에 기초하여 관점 변경을 결정할 수 있다. 정렬 모듈(240)은 이 불일치를 이용하여, 이미지로부터 데이터를 더욱 정확하게 디코딩하기 위해 디코더 모듈(250)에 의해 이용될 수 있는 이미지의 관점 또는 이미지의 다른 공간적 속성을 추론하거나 결정한다.Alignment module 240 compares the intrinsic feature and the reference intrinsic feature to determine alignment, including orientation, scale, or position. For example, if the image containing the custom graphic is an image from the front view, then the intrinsic feature of the custom graphic within the image must match the reference intrinsic feature. Alignment module 240 may determine a view change based on a mismatch between the intrinsic feature and the reference intrinsic feature. The alignment module 240 uses this mismatch to infer or determine the perspective of the image or other spatial attributes of the image that can be used by the decoder module 250 to more accurately decode the data from the image.

도 12a, 도 12b, 및 도 12c는, 맞춤형 기능 패턴을 이용하여 광학 바코드의 디코딩을 가능하게 하는데 이용되는 다양한 이미지 변환을 나타내는 도면이다. 예시적인 실시예에서, 정렬 모듈(240) 또는 디코더 모듈(250)은, 예시적인 광학 바코드들(1200 및 1202) 사이의 천이에 의해 도시된 회전 등의 이미지 변환을 수행한다. 다른 실시예에서, 정렬 모듈(240) 또는 디코더 모듈(250)은 디스큐잉, 스케일 변환, 또는 다른 타입의 이미지 변환을 수행한다. 또 다른 예시적인 실시예에서, 정렬 모듈(240) 또는 디코더 모듈(250)은, 예시적인 광학 바코드(1204 및 1206) 사이의 천이에 의해 도시된 색상 반전 등의 다른 이미지 변환을 수행한다. 정렬 모듈(240) 또는 디코더 모듈(250)은, 이미지 선명화, 노이즈 감소, 또는 다른 이미지 처리 등의 도시되지 않은 다른 이미지 변환을 수행할 수 있다.Figures 12A, 12B, and 12C are diagrams illustrating various image transformations used to enable decoding of an optical bar code using a customizable function pattern. In an exemplary embodiment, alignment module 240 or decoder module 250 performs image conversion, such as rotation, illustrated by the transitions between exemplary optical bar codes 1200 and 1202. In another embodiment, the alignment module 240 or the decoder module 250 performs de-queuing, scale conversion, or other type of image conversion. In another exemplary embodiment, the alignment module 240 or decoder module 250 performs other image conversions, such as color reversal, as illustrated by the transitions between the exemplary optical bar codes 1204 and 1206. Alignment module 240 or decoder module 250 may perform other image transformations not shown, such as image sharpening, noise reduction, or other image processing.

도 12c는 맞춤형 그래픽의 정렬을 결정하는 기술의 예를 나타낸다. 예시적인 광학 바코드(1208)는 0도로부터 약간 떨어져 회전된다. 타원(1210)은, 광학 바코드(1208)의 회전 값 등의 정렬을 결정하기 위해 맞춤형 그래픽에 맞추어질 수 있다. 타원의 장축(1212)은 0도로부터의 회전 값(1214)의 표시를 제공한다(물론, 단축 값 또는 다른 축이, 회전 값을 결정하는데 유사하게 이용될 수 있다). 정렬 모듈(240) 또는 디코더 모듈(250)은, 원래의 배향(1218)으로부터 회전된 예시적인 광학 바코드(1216)에 의해 도시된 바와 같이 회전 값(1214)을 조정하기 위해 이미지 변환을 수행할 수 있다. 이러한 방식으로, 정렬 모듈(240) 또는 디코더 모듈(250)은 맞춤형 그래픽을 이용하여 이미지에 포함된 광학 바코드에 대한 정렬을 결정하여 이미지 내에 인코딩된 데이터를 디코딩하는 것을 보조할 수 있다.Figure 12C shows an example of a technique for determining alignment of custom graphics. The exemplary optical bar code 1208 is rotated slightly off from zero degrees. The ellipse 1210 may be tailored to a custom graphic to determine alignment, such as the rotation value of the optical bar code 1208. [ The long axis 1212 of the ellipse provides an indication of the rotation value 1214 from zero degrees (of course, a short axis value or other axis can be similarly used to determine the rotation value). Alignment module 240 or decoder module 250 may perform image transformation to adjust rotation value 1214 as shown by an exemplary optical bar code 1216 rotated from its original orientation 1218 have. In this manner, the alignment module 240 or the decoder module 250 can assist in deciding the alignment for the optical bar code included in the image using the custom graphics to decode the encoded data in the image.

도 13은 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하기 위한 추가의 예시적인 동작을 나타내는 흐름도이다. 동작 1040에서, 디코더 모듈(250)은 이미지 데이터로부터 이미지의 일부 내에 인코딩된 데이터를 디코딩한다. 동작 1040에 후속하여, 도 13의 동작들은 일부 예시적인 실시예에서 수행된다.Figure 13 is a flow diagram illustrating a further exemplary operation for decoding an optical bar code using a customized function pattern. At operation 1040, decoder module 250 decodes the encoded data within the portion of the image from the image data. Following operation 1040, the operations of FIG. 13 are performed in some exemplary embodiments.

동작 1310에서, 디코더 모듈(250)은 변환된 이미지를 이용한 이미지의 일부 내에 인코딩된 데이터의 디코딩 실패를 결정한다. 예를 들어, 이미지로부터 디코딩된 데이터가 파손되었거나, 불완전하거나, 또는 왜곡된 경우, 디코더 모듈(250)은 데이터의 디코딩 실패를 결정한다. 또 다른 예에서, 이미지 내에 인코딩된 데이터의 일부는 데이터 유효성확인을 위한 것일 수 있다. 즉, 알려진 또는 결정가능한 값이 데이터 내에 인코딩되되, 그 값이 이미지로부터 디코딩된 경우 데이터가 유효하도록 인코딩될 수 있다. 디코더 모듈(250)은, 이미지의 일부 내에 인코딩된 데이터의 디코딩 실패를 결정하기 위해 다양한 다른 방식 및 기술을 채용할 수 있다.At operation 1310, decoder module 250 determines decoding failure of the encoded data within a portion of the image using the transformed image. For example, if the decoded data from the image is broken, incomplete, or distorted, the decoder module 250 determines the decoding failure of the data. In another example, a portion of the encoded data in the image may be for data validation. That is, a known or determinable value is encoded into the data, but the data may be encoded to be valid if the value is decoded from the image. Decoder module 250 may employ various other techniques and techniques to determine decoding failure of encoded data within a portion of an image.

동작 1320에서, 정렬 모듈(240)은 맞춤형 그래픽의 상이한 배향에 따라 이미지를 변환함으로써 또 다른 변환된 이미지를 생성한다. 예를 들어, 정렬 모듈(240)은 180도 회전된 변환된 이미지를 생성하고, 디코더 모듈(250)은 두 번째로 데이터를 디코딩하려고 시도한다. 정렬 모듈(240)은, 과거 스캔에서 디코딩 실패를 자주 해결한 90도 회전 또는 다른 변환 등의 디코딩 실패를 해결할 수 있는 공통 변환을 수행할 수 있다. 일부 실시예에서, 정렬 모듈(240)은, 또 다른 변환된 이미지를 생성할 때 이용할 또 다른 정렬을 결정하기 위해 이미지의 이미지 데이터의 또 다른 분석을 수행한다. 정렬 모듈(240)은, 상이한 타입의 필터들(예컨대, 배향, 색상 감소, 밝기 조작 등)을 맞춤형 그래픽에 적용함으로써 다른 타입들의 변환된 이미지를 수행할 수 있다.In operation 1320, the alignment module 240 generates another transformed image by transforming the image according to the different orientations of the custom graphics. For example, the alignment module 240 generates a rotated 180 degree rotated image, and the decoder module 250 attempts to decode the data a second time. Alignment module 240 may perform a common transform that can resolve decode failures such as 90 degrees rotation or other transformations that often resolve decoding failures in past scans. In some embodiments, the alignment module 240 performs another analysis of the image data of the image to determine another alignment to use when generating another transformed image. Alignment module 240 may perform other types of transformed images by applying different types of filters (e.g., orientation, color reduction, brightness manipulation, etc.) to the custom graphics.

동작 1330에서, 디코더 모듈(250)은 또 다른 변환된 이미지를 이용하여 이미지의 일부 내에 인코딩된 데이터를 디코딩한다. 정렬 모듈(240) 및 디코더 모듈(250)은, 데이터가 이미지로부터 성공적으로 디코딩될 때 끝나는 임의의 횟수의 정렬의 반복을 시도(예를 들어, 설정된 횟수의 시도 또는 무제한의 시도)할 수 있다. 이러한 방식으로, 맞춤형 패턴 시스템(160)은 자기정렬을 위한 마킹을 이용할 수 있다.At operation 1330, the decoder module 250 decodes the encoded data within a portion of the image using another transformed image. Alignment module 240 and decoder module 250 may attempt to iterate (for example, a set number of attempts or an unlimited number of iterations) any number of alignments that end when data is successfully decoded from the image. In this manner, the custom pattern system 160 may utilize marking for self-alignment.

도 13과 관련하여 논의를 더 설명하기 위해, 도 14는 맞춤형 기능 패턴을 이용하여 광학 바코드를 디코딩하는 예를 도시하는 도면(1400)이다. 예시적인 광학 바코드(1410)는 빈 원으로 마킹을 위한 위치를 나타낸다. 광학 바코드(1410)의 각 빈 원은 마커를 위한 위치이다. 예시적인 광학 바코드(1420)는 마킹 위치와 마킹 사이의 오정렬을 나타낸다. 예시적인 광학 바코드(1430)는 마킹과 마킹 위치 사이의 일치되는 정렬을 나타낸다.To further illustrate the discussion with reference to FIG. 13, FIG. 14 is a drawing 1400 illustrating an example of decoding an optical bar code using a customized function pattern. An exemplary optical bar code 1410 represents a location for marking with an empty circle. Each empty circle of the optical barcode 1410 is a position for the marker. The exemplary optical bar code 1420 represents the misalignment between the marking position and the marking. An exemplary optical bar code 1430 represents the aligned alignment between the marking and marking positions.

이제 도 15 내지 도 16을 참조하면, 여기서 설명된(예를 들어, 도 15, 도 16, 및 도 18) 사용자 인터페이스들은 특정한 예시적인 사용자 인터페이스 및 사용자 인터페이스 요소들을 도시하지만, 이들은 비제한적인 예일 뿐이고, 많은 다른 대안적인 사용자 인터페이스 및 사용자 인터페이스 요소들이 프리젠테이션 모듈(220)에 의해 생성되어 사용자에게 프리젠팅될 수 있다. 여기서 설명된 디스플레이의 대안적 프리젠테이션은, 추가적인 정보, 그래픽, 옵션 등을 포함하고; 다른 프레젠테이션은 더 적은 정보를 포함하거나, 사용자가 쉽게 이용할 수 있도록 요약 정보를 제공한다는 점에 유의한다.Referring now to Figures 15-16, the user interfaces described herein (e.g., Figures 15, 16, and 18) illustrate specific exemplary user interface and user interface elements, but these are only non-limiting examples Many other alternative user interfaces and user interface elements may be generated by the presentation module 220 and presented to the user. Alternative presentations of the display described herein include additional information, graphics, options, and the like; Note that other presentations may contain less information or provide summary information that is readily available to the user.

도 15는 광학 바코드를 식별하기 위한 예시적인 사용자 인터페이스(1510)를 도시하는 사용자 인터페이스도(1500)이다. 사용자 인터페이스도(1500)에서, 사용자 인터페이스(1510)는 사용자 디바이스(예를 들어, 클라이언트 디바이스(110), 사용자 디바이스(414))의 카메라 센서로부터 포착된 실질적으로 실시간 이미지를 나타내고 있다. 사용자 인터페이스(1510)는, 아래에 디스플레이되는 실질적으로 실시간 이미지 위에 중첩되거나 오버레이된 그래픽 및 사용자 인터페이스 요소를 포함할 수 있다. 예를 들어, 사용자 인터페이스 요소(1520)는 광학 바코드의 식별을 나타내는 브래킷이다. 사용자 인터페이스(1510)는, 특정한 광학 바코드의 성공적인 스캔 또는 실패한 스캔을 사용자에게 표시할 수 있다.15 is a user interface diagram 1500 illustrating an exemplary user interface 1510 for identifying optical barcodes. In user interface diagram 1500, user interface 1510 represents a substantially real-time image captured from a camera sensor of a user device (e.g., client device 110, user device 414). The user interface 1510 may include graphical and user interface elements superimposed or overlaid on a substantially real-time image displayed below. For example, the user interface element 1520 is a bracket that indicates the identification of the optical bar code. The user interface 1510 may display to the user a successful scan or a failed scan of a particular optical bar code.

도 16은 광학 바코드와 연관된 동작을 수행하기 위한 예시적인 사용자 인터페이스(1610)를 도시하는 사용자 인터페이스도(1600)이다. 한 예시적인 실시예에서, 사용자 인터페이스(1610)는 도 15의 사용자 인터페이스(1510) 이후에 디스플레이된다(예를 들어, 성공적인 스캔 후에, 스캔과 관련된 다양한 동작 옵션이 디스플레이된다). 사용자 인터페이스(1610)는, 사용자 인터페이스 요소(1620) 등의 특정한 광학 바코드를 검출하는 것과 연관된 다양한 동작 옵션을 포함할 수 있다. 일부 실시예에서, 특정한 동작은, 특정한 광학 바코드를 검출하고 디코딩하는 것에 응답하여 맞춤형 패턴 시스템(160)에 의해 자동으로 수행된다.16 is a user interface diagram 1600 illustrating an exemplary user interface 1610 for performing operations associated with optical bar codes. In one exemplary embodiment, the user interface 1610 is displayed after the user interface 1510 of FIG. 15 (e.g., after a successful scan, various operational options associated with the scan are displayed). User interface 1610 may include various operational options associated with detecting a particular optical bar code, such as user interface element 1620. [ In some embodiments, certain operations are performed automatically by the custom pattern system 160 in response to detecting and decoding a particular optical bar code.

추가의 예시적인 실시예에서, 동작은 맞춤형 기능 패턴(예를 들어, 스냅코드)을 이용하는 광학 바코드에 대한 스캐닝 기능을 제공하는 소프트웨어에 독점적이다. 일부 실시예에서, 광학 바코드를 스캔하는 소프트웨어는 서버와의 통신없이 소정의 독점적 동작을 수행할 수 있다. 이것은, 반드시 다른 제3자 소프트웨어 애플리케이션에 의해 공개적으로 디코딩할 수 있지는 않은 맞춤형 기능 패턴의 독점적 브랜드화된 성질 때문이다. 스냅코드는, 브랜드화된 광학 바코드를 스캔하는 소프트웨어(예를 들어, 앱 등의 모바일 컴퓨팅 소프트웨어)는 그 브랜드화된 광학 바코드와 관련될 가능성이 많기 때문에 이러한 동작을 명시할 수 있다.In a further exemplary embodiment, the operation is proprietary to software that provides a scanning function for an optical barcode using a customized function pattern (e.g., a snap code). In some embodiments, the software that scans the optical bar code may perform certain proprietary operations without communicating with the server. This is due to the exclusively branded nature of the customized function pattern, which can not necessarily be publicly decoded by other third party software applications. Snap codes can specify this behavior because software that scans branded optical barcodes (for example, mobile computing software such as apps) is likely to be associated with the branded optical barcode.

도 17은 맞춤형 기능 패턴을 이용하여 광학 바코드를 생성하기 위한 예시적인 동작을 나타내는 흐름도이다. 방법(1700)의 동작들은 맞춤형 패턴 시스템(160)의 컴포넌트들에 의해 수행될 수 있고, 이하에서는 예시의 목적을 위해 설명된다.Fig. 17 is a flowchart showing an exemplary operation for generating an optical bar code using a customized function pattern. Fig. The operations of method 1700 may be performed by components of custom pattern system 160 and are described below for illustrative purposes.

동작 1710에서, 통신 모듈(210)은 맞춤형 기능 패턴을 이용하는 광학 바코드 등의 머신-판독가능한 이미지를 생성하라는 요청을 수신한다. 일부 실시예에서, 요청은, 이미지로 인코딩할 사용자 명시된 데이터를 포함한다.At operation 1710, the communication module 210 receives a request to create a machine-readable image, such as an optical barcode, using a customized function pattern. In some embodiments, the request includes user specified data to be encoded into an image.

동작 1720에서, 인코더 모듈(270)은, 사용자 명시된 데이터를 인코딩하는 마크들의 머신-판독가능한 배열을 렌더링한다. 예를 들어, 마크는, 도트, 정사각형, 또는 미리결정된 패턴으로 배열된 기타의 마킹을 포함할 수 있다. 예시적인 실시예에서, 배열 내의 특정한 위치에서의 마크의 존재는 데이터를 나타낸다.At operation 1720, the encoder module 270 renders a machine-readable arrangement of marks that encode user specified data. For example, the mark may comprise dots, squares, or other markings arranged in a predetermined pattern. In an exemplary embodiment, the presence of a mark at a particular location in the array represents data.

동작 1730에서, 인코더 모듈(270)은, 머신-판독가능한 이미지에 포함된 맞춤형 그래픽의 위치에 관해 머신-판독가능한 이미지 내의 마크들의 머신-판독가능한 배열을 위치시킴으로써 머신-판독가능한 이미지를 생성한다. 예를 들어, 맞춤형 그래픽은 광학 바코드의 중심에 위치하거나 또는 그 외의 곳(예를 들어, 도 3a 및 3b의 예시적인 광학 바코드)에 위치할 수 있다.At operation 1730, the encoder module 270 generates a machine-readable image by placing a machine-readable arrangement of marks in the machine-readable image with respect to the location of the custom graphics contained in the machine-readable image. For example, the custom graphic may be located in the center of the optical bar code or may be located elsewhere (e.g., the exemplary optical bar code of FIGS. 3A and 3B).

동작 1740에서, 통신 모듈(210)은 머신-판독가능한 이미지를 저장 또는 전송한다. 예를 들어, 통신 모듈(210)은, 사용자 디바이스, 서버, 또는(로컬 또는 원격으로 저장된) 다른 스토리지 저장소에 머신-판독가능한 이미지를 저장할 수 있다. 다른 예들에서, 통신 모듈(210)은, 머신-판독가능한 이미지를, 사용자 디바이스, 서버, 또는 하나 이상의 다른 디바이스에 전송한다.At operation 1740, communication module 210 stores or transmits a machine-readable image. For example, communication module 210 may store a machine-readable image on a user device, a server, or other storage repository (stored locally or remotely). In other examples, the communication module 210 transmits the machine-readable image to a user device, a server, or one or more other devices.

도 18은 맞춤형 그래픽을 이용하여 광학 바코드(1820)를 생성하기 위한 예시적인 사용자 인터페이스(1810)를 도시하는 사용자 인터페이스도(1800)이다. 사용자 인터페이스 요소(1830)는 머신-판독가능한 이미지를 생성, 공유 또는 저장하기 위한 옵션을 사용자에게 제공한다. 일부 실시예에서, 사용자 인터페이스도(1800)는, 머신-판독가능한 이미지로 인코딩할 사용자-명시된 데이터(예를 들어, 소셜 네트워킹 서비스 멤버 식별자, 웹 사이트 주소, 또는 또 다른 정보)를 수신하도록 구성된 사용자 인터페이스를 포함한다.18 is a user interface diagram 1800 illustrating an exemplary user interface 1810 for creating an optical bar code 1820 using custom graphics. User interface element 1830 provides the user with an option to create, share or store machine-readable images. In some embodiments, the user interface diagram 1800 includes a user interface 1800 configured to receive user-specified data (e.g., a social networking service member identifier, website address, or other information) to encode with a machine- Interface.

도 19은, 일부 실시예에 따른, 모바일 운영 체제(예를 들어, IOS™, ANDROID™, WINDOWS® Phone 또는 기타의 모바일 운영 체제)을 실행하는 예시적인 모바일 디바이스(1900)를 나타낸다. 한 실시예에서, 모바일 디바이스(1900)는 사용자(1902)로부터 촉각 데이터를 수신하도록 동작가능한 터치 스크린을 포함한다. 예를 들어, 사용자(1902)는 모바일 디바이스(1900)를 물리적으로 터치(1904)할 수 있고, 터치(1904)에 응답하여, 모바일 디바이스(1900)는, 터치 위치, 터치 힘, 또는 제스쳐 동작 등의 촉각 데이터를 결정할 수 있다. 다양한 예시적인 실시예에서, 모바일 디바이스(1900)는 애플리케이션을 론칭하거나 모바일 디바이스(1900)의 다양한 양태를 관리하도록 동작가능한 홈 스크린(1906)(예를 들어 IOS™ 상의 Springboard)을 디스플레이한다. 일부 예시적인 실시예에서, 홈 스크린(1906)은, 배터리 수명, 연결성, 또는 기타의 하드웨어 상태 등의, 상태 정보를 제공한다. 사용자(1902)는 각각의 사용자 인터페이스 요소에 의해 점유된 영역을 터치함으로써 사용자 인터페이스 요소를 활성화할 수 있다. 이러한 방식으로, 사용자(1902)는 모바일 디바이스(1900)의 애플리케이션들과 상호작용한다. 예를 들어, 홈 스크린(1906)에 포함된 특정한 아이콘에 의해 점유된 영역을 터치하는 것은 특정한 아이콘에 대응하는 애플리케이션의 론칭을 야기한다.FIG. 19 illustrates an exemplary mobile device 1900 executing a mobile operating system (e.g., IOS ™, ANDROID ™, WINDOWS® Phone, or other mobile operating system), according to some embodiments. In one embodiment, the mobile device 1900 includes a touch screen operable to receive tactile data from the user 1902. For example, the user 1902 may physically touch (1904) the mobile device 1900, and in response to the touch 1904, the mobile device 1900 may provide a touch location, touch force, Of the tactile sense data. In various exemplary embodiments, the mobile device 1900 displays a home screen 1906 (e.g., Springboard on IOS ™) that is operable to launch applications or manage various aspects of the mobile device 1900. In some exemplary embodiments, the home screen 1906 provides status information, such as battery life, connectivity, or other hardware status. The user 1902 may activate the user interface element by touching the area occupied by each user interface element. In this manner, the user 1902 interacts with the applications of the mobile device 1900. For example, touching an area occupied by a particular icon included in the home screen 1906 causes launching of an application corresponding to a particular icon.

네이티브 애플리케이션(예를 들어, Objective-C, Swift, 또는 IOS™ 상에서 실행중인 다른 적절한 언어로 프로그램된 애플리케이션, 또는 ANDROID™에서 실행되는 Java로 프로그램된 애플리케이션), 모바일 웹 애플리케이션(예를 들어, HTML5(Hypertext Markup Language-5)로 작성된 애플리케이션) 또는 하이브리드 애플리케이션(예를 들어, HTML5 세션을 론칭하는 네이티브 쉘 애플리케이션) 등의, ("앱"이라고도 하는) 많은 다양한 애플리케이션들이 모바일 디바이스(1900) 상에서 실행될 수 있다. 예를 들어, 모바일 디바이스(1900)는, 메시징 앱, 오디오 녹음 앱, 카메라 앱, 북 리더 앱, 미디어 앱, 피트니스 앱, 파일 관리 앱, 위치 앱, 브라우저 앱, 설정 앱, 연락처 앱, 전화 통화 앱, 또는 기타의 앱(예를 들어, 게임 앱, 소셜 네트워킹 앱, 바이오메트릭 모니터링 앱)을 포함한다. 또 다른 예에서, 모바일 디바이스(1900)는, 일부 실시예와 일치하는, 사용자가 미디어 콘텐츠를 포함하는 단기 메시지(ephemeral message)를 교환하는 것을 허용하는 SNAPCHAT® 등의 소셜 메시징 앱(1908)을 포함한다. 이 예에서, 소셜 메시징 앱(1908)은 여기서 설명된 실시예의 양태들을 포함할 수 있다.(E. G., An application programmed in another suitable language running on Objective-C, Swift, or IOS (TM), or an application programmed with Java running on ANDROID (TM)), a mobile web application A number of various applications (also referred to as "apps "), such as applications written in Hypertext Markup Language 5) or hybrid applications (e.g., native shell applications launching HTML5 sessions) . For example, mobile device 1900 may be a messaging app, an audio recording app, a camera app, a book reader app, a media app, a fitness app, a file management app, a location app, a browser app, , Or other apps (e.g., game apps, social networking apps, biometric monitoring apps). In another example, mobile device 1900 includes a social messaging application 1908, such as SNAPCHAT, which allows a user to exchange ephemeral messages containing media content, consistent with some embodiments. do. In this example, the social messaging application 1908 may include aspects of the embodiments described herein.

소정 실시예들은, 여기서 로직 또는 다수의 컴포넌트, 모듈 또는 메커니즘을 포함하는 것으로서 설명된다. 모듈은, 소프트웨어 모듈(예를 들어, 머신-판독가능한 매체 상에 구현된 코드) 또는 하드웨어 모듈을 구성할 수 있다. "하드웨어 모듈"은, 소정의 동작을 수행할 수 있는 유형 유닛(tangible unit)이며, 소정의 물리적 방식으로 구성되거나 배열될 수 있다. 다양한 예시적인 실시예에서, 하나 이상의 컴퓨터 시스템(예를 들어, 독립형 컴퓨터 시스템, 클라이언트 컴퓨터 시스템, 또는 서버 컴퓨터 시스템) 또는 컴퓨터 시스템의 하나 이상의 하드웨어 모듈(예를 들어, 프로세서 또는 프로세서 그룹)는, 소프트웨어(예를 들어, 애플리케이션 또는 애플리케이션 부분)에 의해 여기서 설명된 소정의 동작을 수행하도록 동작하는 하드웨어 모듈로서 구성될 수 있다.Certain embodiments are described herein as including logic or a plurality of components, modules, or mechanisms. A module may comprise a software module (e.g., code implemented on a machine-readable medium) or a hardware module. A "hardware module" is a tangible unit capable of performing certain operations and may be constructed or arranged in a predetermined physical manner. In various exemplary embodiments, one or more hardware modules (e.g., a processor or group of processors) of one or more computer systems (e.g., a standalone computer system, a client computer system, or a server computer system) May be configured as a hardware module that is operative to perform certain operations described herein by a processor (e.g., an application or application portion).

일부 실시예에서, 하드웨어 모듈은, 기계적으로, 전자적으로, 또는 이들의 임의의 적절한 조합으로 구현될 수 있다. 예를 들어, 하드웨어 모듈은 소정의 동작들을 수행하도록 영구적으로 구성된 전용 회로 또는 로직을 포함할 수 있다. 예를 들어, 하드웨어 모듈은, FPGA(Field-Programmable Gate Array) 또는 ASIC(Application Specific Integrated Circuit) 등의 특별-목적 프로세서일 수 있다. 하드웨어 모듈은 또한, 소정의 동작들을 수행하도록 소프트웨어에 의해 일시적으로 구성된 프로그램가능한 로직 또는 회로를 포함할 수 있다. 예를 들어, 하드웨어 모듈은, 범용 프로세서 또는 다른 프로그램가능한 프로세서에 의해 실행가능한 소프트웨어를 포함할 수 있다. 일단 이러한 소프트웨어에 의해 일단 구성되고 나면, 하드웨어 모듈은 구성된 기능을 수행하도록 고유하게 맞춤화된 특정한 머신(또는 머신의 특정한 컴포넌트)가 되고 더 이상 범용 프로세서가 아니다. 기계적으로, 전용 및 영구적으로 구성된 회로로, 또는 일시적으로 구성된 회로(예를 들어, 소프트웨어에 의해 구성됨)로 하드웨어 모듈을 구현하려는 결정은, 비용 및 시간 고려사항에 의해 결정될 수 있다는 것을 이해할 것이다.In some embodiments, the hardware modules may be implemented mechanically, electronically, or any suitable combination thereof. For example, a hardware module may include dedicated circuitry or logic configured to perform certain operations permanently. For example, the hardware module may be a special-purpose processor such as an FPGA (Field-Programmable Gate Array) or an ASIC (Application Specific Integrated Circuit). The hardware module may also include programmable logic or circuitry temporarily configured by software to perform certain operations. For example, the hardware module may comprise software executable by a general purpose processor or other programmable processor. Once configured by such software, the hardware module becomes a specific machine (or a specific component of the machine) that is uniquely tailored to perform the configured function and is no longer a general purpose processor. It will be appreciated that the decision to implement a hardware module in a mechanically, duly and permanently configured circuit, or in a transiently configured circuit (e.g., configured by software), may be determined by cost and time considerations.

따라서, "하드웨어 모듈"이라는 구문은, 소정 방식으로 동작하거나 여기서 설명된 소정 동작들을 수행하도록 물리적으로 구성되거나, 영구적으로 구성되거나(예를 들어, 하드 와이어드) 또는 일시적으로 구성된(예를 들어, 프로그래밍)된 유형 엔티티를 포함하는 것으로 이해되어야 한다. 여기서 사용될 때, "하드웨어-구현된 모듈"이란 하드웨어 모듈을 말한다. 하드웨어 모듈들이 일시적으로 구성되는(예를 들어, 프로그램되는) 실시예들을 고려할 때, 하드웨어 모듈들 각각은 임의의 한 시점에서 구성되거나 인스턴스화될 필요는 없다. 예를 들어, 하드웨어 모듈이 소프트웨어에 의해 특별-목적 프로세서가 되도록 구성된 범용 프로세서를 포함하는 경우, 범용 프로세서는 상이한 시간들에서 (예를 들어, 상이한 하드웨어 모듈들을 포함하는) 각각 상이한 특별-목적 프로세서들로서 구성될 수 있다 . 소프트웨어는, 그에 따라 특정한 프로세서 또는 프로세서들을 구성하여, 예를 들어 소정의 한 시점에서 특정한 하드웨어 모듈을 구성하고 상이한 한 시점에서 상이한 하드웨어 모듈을 구성한다.Thus, the phrase "hardware module" is intended to encompass all types of hardware components, including, but not limited to, those that are physically configured to perform certain operations, Quot;) < / RTI > type entity. As used herein, "hardware-implemented module" refers to a hardware module. Considering embodiments in which hardware modules are temporarily configured (e.g., programmed), each of the hardware modules need not be configured or instantiated at any one time. For example, if a hardware module includes a general-purpose processor configured to be a special-purpose processor by software, then the general-purpose processor may be used as each of the different special-purpose processors at different times (e.g., including different hardware modules) Lt; / RTI > The software thereby configures a particular processor or processors to configure a particular hardware module, for example at a given point in time, and to configure a different hardware module at a different point in time.

하드웨어 모듈은 다른 하드웨어 모듈에 정보를 제공하고 다른 하드웨어 모듈로부터 정보를 수신할 수 있다. 따라서, 설명된 하드웨어 모듈들은 통신가능하게 결합된 것으로 간주될 수 있다. 복수의 하드웨어 모듈이 동시에 존재하는 경우, 통신은 2개 이상의 하드웨어 모듈들 사이에서 (예를 들어, 적절한 회로 및 버스를 통한) 신호 전송을 통해 달성될 수 있다. 복수의 하드웨어 모듈들이 상이한 시간들에서 구성되거나 인스턴스화되는 실시예에서, 이러한 하드웨어 모듈들 사이의 통신은, 예를 들어, 복수의 하드웨어 모듈들이 액세스하는 메모리 구조 내의 정보의 저장 및 검색을 통해 달성될 수 있다. 예를 들어, 하나의 하드웨어 모듈은 소정의 동작을 수행하고 그 동작의 출력을 통신가능하게 결합된 메모리 디바이스에 저장할 수 있다. 그 다음, 추가 하드웨어 모듈은, 나중에, 메모리 디바이스에 액세스하여 저장된 출력을 회수 및 처리할 수 있다. 하드웨어 모듈은 또한, 입력 또는 출력 디바이스와의 통신을 개시할 수 있고, 자원(예를 들어, 정보 모음)에 관해 동작할 수 있다.A hardware module may provide information to other hardware modules and may receive information from other hardware modules. Thus, the described hardware modules may be considered to be communicatively coupled. If multiple hardware modules are present at the same time, communication may be accomplished through signal transmission between two or more hardware modules (e.g., via appropriate circuitry and buses). In embodiments where a plurality of hardware modules are configured or instantiated at different times, communication between such hardware modules may be accomplished through, for example, storage and retrieval of information in a memory structure accessed by a plurality of hardware modules have. For example, one hardware module may perform some operation and store the output of the operation in a communicatively coupled memory device. The additional hardware module may then access the memory device to recover and process the stored output. A hardware module may also initiate communication with an input or output device and may operate on a resource (e.g., a collection of information).

여기서 설명된 예시적인 방법들의 다양한 동작들은, 적어도 부분적으로, 관련 동작들을 수행하도록 (예를 들어, 소프트웨어에 의해) 일시적으로 구성되거나 영구적으로 구성된 하나 이상의 프로세서에 의해 수행될 수 있다. 일시적으로 또는 영구적으로 구성되어 있는지에 관계없이, 이러한 프로세서들은 여기서 설명된 하나 이상의 동작 또는 기능을 수행하도록 동작하는 프로세서-구현된 모듈들을 구성한다. 여기서 사용될 때, "프로세서-구현된 모듈"이란 하나 이상의 프로세서를 이용하여 구현된 하드웨어 모듈을 말한다.The various operations of the exemplary methods described herein may be performed, at least in part, by one or more processors temporarily configured or permanently configured (e.g., by software) to perform related operations. These processors, whether temporarily or permanently configured, constitute processor-implemented modules that operate to perform one or more of the operations or functions described herein. As used herein, "processor-implemented module " refers to a hardware module implemented using one or more processors.

유사하게, 여기서 설명된 방법들은 하드웨어의 한 예인 특정한 프로세서 또는 프로세서들로 적어도 부분적으로 프로세서-구현될 수 있다. 예를 들어, 방법의 동작들 중 적어도 일부는, 하나 이상의 프로세서 또는 프로세서-구현된 모듈에 의해 수행될 수 있다. 게다가, 하나 이상의 프로세서는 또한, "클라우드 컴퓨팅" 환경에서 관련 동작의 수행을 지원하도록 또는 "서비스로서의 소프트웨어"(SaaS; software as a service)로서 동작할 수 있다. 예를 들어, 동작들 중 적어도 일부는, (프로세서들을 포함하는 머신들의 예로서의) 컴퓨터들의 그룹에 의해 수행될 수 있고, 이들 동작들은 네트워크(예를 들어, 인터넷) 및 하나 이상의 적절한 인터페이스(예를 들어, 애플리케이션 프로그램 인터페이스(API))를 통해 액세스가능하다.Similarly, the methods described herein may be at least partially processor-implemented with a particular processor or processors, which is an example of hardware. For example, at least some of the operations of the method may be performed by one or more processors or processor-implemented modules. In addition, the one or more processors may also operate as a " software as a service " (SaaS) to support the performance of related operations in a "cloud computing" environment. For example, at least some of the operations may be performed by a group of computers (as an example of machines including processors), which may be a network (e.g., the Internet) and one or more appropriate interfaces , An application program interface (API)).

소정 동작들의 수행은, 단일 머신 내에 존재할 뿐만 아니라 다수의 머신들에 걸쳐 배치된, 프로세서들 사이에서 분산될 수 있다. 일부 예시적인 실시예에서, 프로세서 또는 프로세서-구현된 모듈들은 단일의 지리적 위치에(예를 들어, 가정 환경, 사무실 환경, 또는 서버 팜 내에) 위치할 수 있다. 다른 예시적인 실시예에서, 프로세서 또는 프로세서-구현된 모듈들은 다수의 지리적 위치에 걸쳐 분산된다.The performance of certain operations may be distributed among the processors not only within a single machine but also across multiple machines. In some exemplary embodiments, the processor or processor-implemented modules may be located in a single geographic location (e.g., in a home environment, office environment, or server farm). In another exemplary embodiment, the processor or processor-implemented modules are distributed across multiple geographic locations.

상기 도면들과 연계하여 설명된 모듈, 방법, 애플리케이션 등은, 일부 실시예에서, 머신 및 연관된 소프트웨어 아키텍쳐의 정황에서 구현된다. 이하의 섹션은 개시된 실시예들에서 이용하기에 적합한 대표적인 소프트웨어 아키텍쳐(들) 및 머신(예를 들어, 하드웨어) 아키텍쳐를 설명한다.The modules, methods, applications, etc. described in connection with the above figures are, in some embodiments, implemented in the context of the machine and the associated software architecture. The following sections describe exemplary software architecture (s) and machine (e.g., hardware) architectures suitable for use in the disclosed embodiments.

소프트웨어 아키텍쳐는 하드웨어 아키텍쳐와 연계하여 이용되어 특정한 목적에 맞게 조정된 디바이스 및 머신을 생성한다. 예를 들어 특정한 소프트웨어 아키텍쳐와 결합된 특정한 하드웨어 아키텍쳐는, 모바일 전화, 태블릿 디바이스 등의 모바일 디바이스를 생성할 것이다. 약간 상이한 하드웨어 및 소프트웨어 아키텍쳐는 "사물 인터넷"에서 이용하기 위한 스마트 디바이스를 생성할 수 있다. 역시 또 다른 조합은, 클라우드 컴퓨팅 아키텍쳐 내에서 이용하기 위한 서버 컴퓨터를 생성한다. 본 기술분야의 통상의 기술자라면 본 명세서에 포함된 개시내용과 상이한 정황에서 본 발명을 구현하는 방법을 용이하게 이해할 수 있으므로, 이러한 소프트웨어 및 하드웨어 아키텍쳐의 모든 조합이 본 명세서에 제시되지는 않는다.Software architectures are used in conjunction with hardware architectures to create devices and machines tailored for specific purposes. For example, a particular hardware architecture combined with a particular software architecture will create mobile devices such as mobile phones, tablet devices, and the like. A slightly different hardware and software architecture can create smart devices for use in the "things Internet ". Yet another combination creates a server computer for use within the cloud computing architecture. Any combination of such software and hardware architectures is not provided herein, as one of ordinary skill in the art can readily understand how to implement the invention in different contexts than the disclosure contained herein.

도 20은 여기서 설명된 다양한 하드웨어 아키텍쳐와 연계하여 이용될 수 있는 대표적인 소프트웨어 아키텍쳐(2002)를 도시하는 블록도(2000)이다. 도 20은 소프트웨어 아키텍쳐의 비제한적인 예일 뿐이며, 여기서 설명된 기능을 가능하게 하기 위해 많은 다른 아키텍쳐가 구현될 수 있다는 것을 이해할 것이다. 소프트웨어 아키텍쳐(2002)는, 특히, 프로세서(2110), 메모리/스토리지(2130), 및 I/O 컴포넌트(2150)를 포함하는 도 21의 머신(2100) 등의 하드웨어 상에서 실행될 수 있다. 대표적인 하드웨어 계층(2004)이 예시되어 있으며, 예를 들어, 도 21의 머신(2100)을 나타낼 수 있다. 대표적인 하드웨어 계층(2004)은 연관된 실행가능한 명령어(2008)들을 갖는 하나 이상의 처리 유닛(2006)을 포함한다. 실행가능한 명령어(2008)는, 상기의 도면 및 설명에서의 방법, 모듈 등의 구현을 포함하는 소프트웨어 아키텍쳐(2002)의 실행가능한 명령어를 나타낸다. 하드웨어 계층(2004)은 또한, 실행가능한 명령어(2008)를 역시 갖는 메모리 및 스토리지 모듈(2010)을 포함한다. 하드웨어 계층(2004)은 또한, 머신(2100)의 일부로서 예시된 기타의 하드웨어 등의, 하드웨어 계층(2004)의 기타 임의의 하드웨어를 나타내는, 2012로 표시된 기타의 하드웨어를 포함할 수 있다.20 is a block diagram 2000 illustrating an exemplary software architecture 2002 that may be utilized in conjunction with the various hardware architectures described herein. 20 is a non-limiting example of a software architecture, and it will be appreciated that many different architectures may be implemented to enable the functionality described herein. The software architecture 2002 may be specifically executed on hardware such as the machine 2100 of Figure 21 including a processor 2110, a memory / storage 2130, and an I / O component 2150. A representative hardware layer 2004 is illustrated, and may, for example, represent the machine 2100 of FIG. Exemplary hardware layer 2004 includes one or more processing units 2006 having associated executable instructions 2008. Executable instructions 2008 represent executable instructions of the software architecture 2002 that include implementations of the methods, modules, and the like in the drawings and description above. The hardware layer 2004 also includes a memory and storage module 2010 that also has executable instructions 2008. [ The hardware layer 2004 may also include other hardware labeled 2012 that represents any other hardware of the hardware layer 2004, such as the other hardware illustrated as part of the machine 2100.

도 20의 예시적인 아키텍쳐에서, 소프트웨어(2002)는 각각의 계층이 특정한 기능을 제공하는 계층들의 스택으로서 개념화될 수 있다. 예를 들어, 소프트웨어(2002)는, 운영 체제(2014), 라이브러리(2016), 프레임워크/미들웨어(2018), 애플리케이션(2020), 및 프리젠테이션 계층(2022) 등의 계층들을 포함할 수 있다. 동작적으로, 애플리케이션(2020) 또는 계층들 내의 기타의 컴포넌트는, 소프트웨어 스택을 통해 애플리케이션 프로그래밍 인터페이스(API) 호출(2024)을 기동할 수 있고, API 호출(2024)에 응답하여 메시지(2026)로 예시된 응답, 반환된 값 등을 수신할 수 있다. 예시된 계층들은 본질적으로 대표적인 것이며 모든 소프트웨어 아키텍쳐가 모든 계층을 갖는 것은 아니다. 예를 들어, 일부 모바일 또는 특별 목적 운영 체제는 프레임워크/미들웨어 계층(2018)을 제공하지 않을 수도 있는 반면, 다른 것들은 이러한 계층을 제공할 수도 있다. 다른 소프트웨어 아키텍쳐는 추가의 또는 상이한 계층을 포함할 수 있다.In the exemplary architecture of Fig. 20, the software 2002 can be conceptualized as a stack of layers, each layer providing a specific function. For example, the software 2002 may include layers such as an operating system 2014, a library 2016, a framework / middleware 2018, an application 2020, and a presentation layer 2022. The application 2020 or other components in the layers may invoke an application programming interface (API) call 2024 via the software stack and may send a message 2026 in response to the API call 2024 An example response, a value returned, and so on. The illustrated layers are exemplary in nature and not all software architectures have all layers. For example, some mobile or special-purpose operating systems may not provide a framework / middleware layer 2018, while others may provide such a layer. Other software architectures may include additional or different layers.

운영 체제(2014)는 하드웨어 자원을 관리하고 공통 서비스를 제공할 수 있다. 운영 체제(2014)는, 예를 들어, 커널(2028), 서비스(2030) 및 드라이버(2032)를 포함할 수 있다. 커널(2028)은 하드웨어와 기타의 소프트웨어 계층 사이의 추상화 계층으로서 작용할 수 있다. 예를 들어, 커널(2028)은, 메모리 관리, 프로세서 관리(예를 들어, 스케쥴링), 컴포넌트 관리, 네트워킹, 보안 설정 등을 담당할 수 있다. 서비스(2030)는 다른 소프트웨어 계층들을 위한 다른 공통 서비스들을 제공할 수 있다. 드라이버(2032)는 기저 하드웨어를 제어하거나 이와 인터페이스하는 것을 담당할 수 있다. 예를 들어, 드라이버(2032)는, 하드웨어 구성에 따라, 디스플레이 드라이버, 카메라 드라이버, BLUETOOTH® 드라이버, 플래시 메모리 드라이버, 직렬 통신 드라이버(예를 들어, USB(Universal Serial Bus) 드라이버), WI-FI® 드라이버, 오디오 드라이버, 전력 관리 드라이버 등을 포함할 수 있다. 예시적인 실시예에서, 운영 체제(2014)는, 하드웨어 가속화된 이미지 처리, 또는 광학 센서 또는 광 센서 데이터로의 저레벨 액세스 등의 이미지 포착 서비스 등의, 이미지 처리 서비스들을 제공할 수 있는 이미징 서비스(2033)를 포함한다.The operating system 2014 can manage hardware resources and provide a common service. The operating system 2014 may include, for example, a kernel 2028, a service 2030, and a driver 2032. The kernel 2028 may act as an abstraction layer between hardware and other software layers. For example, the kernel 2028 may be responsible for memory management, processor management (e.g., scheduling), component management, networking, security settings, and the like. Service 2030 may provide other common services for different software layers. The driver 2032 may be responsible for controlling or interfacing with the base hardware. For example, the driver 2032 may be a display driver, a camera driver, a BLUETOOTH® driver, a flash memory driver, a serial communication driver (for example, a USB (Universal Serial Bus) driver), a WI- Drivers, audio drivers, power management drivers, and the like. In an exemplary embodiment, the operating system 2014 includes an imaging service 2033 that can provide image processing services, such as hardware accelerated image processing, or image capture services such as low-level access to optical or light sensor data ).

라이브러리(2016)는, 애플리케이션(2020) 또는 다른 컴포넌트 또는 계층에 의해 이용될 수 있는 공통의 인프라스트럭쳐를 제공할 수 있다. 라이브러리(2016)는 통상적으로, 다른 소프트웨어 모듈이 기저 운영 체제(2014) 기능(예를 들어, 커널(2028), 서비스(2030) 또는 드라이버(2032))과 직접 인터페이스하는 것보다 용이한 방식으로 태스크를 수행하는 것을 허용하는 기능을 제공한다. 라이브러리(2016)는, 메모리 할당 기능, 문자열 조작 기능, 수학 기능 등의 기능을 제공할 수 있는 시스템 라이브러리(2034)(예를 들어, C 표준 라이브러리)를 포함할 수 있다. 또한, 라이브러리(2016)는, 미디어 라이브러리(예를 들어, MPREG4, H.264, MP3, AAC, AMR, JPG 또는 PNG 등의 다양한 미디어 포멧의 프리젠테이션 및 조작을 지원하는 라이브러리), 그래픽 라이브러리(예를 들어, 디스플레이의 그래픽 콘텐츠에서 2D 및 3D를 렌더링하는데 이용할 수 있는 OpenGL 프레임워크), 데이터베이스 라이브러리(예를 들어, 다양한 관계형 데이터베이스 기능을 제공할 수 있는 SQLite), 웹 라이브러리(예를 들어, 웹 브라우징 기능을 제공할 수 있는 WebKit) 등의 API 라이브러리들(2036)을 포함할 수 있다. 라이브러리(2016)는 또한, 많은 다른 API를 애플리케이션(2020) 및 다른 소프트웨어 컴포넌트/모듈에 제공하는 다양한 다른 라이브러리(2038)를 포함할 수 있다. 한 예시적인 실시예에서, 라이브러리(2016)는 맞춤형 패턴 시스템(160)에 의해 이용될 수 있는 이미지 처리 또는 이미지 포착 기능을 제공하는 이미징 라이브러리(2039)를 포함한다.The library 2016 may provide a common infrastructure that may be utilized by applications 2020 or other components or layers. The library 2016 typically includes a task 2026 that facilitates the execution of a task 202 in a manner that is easier than other software modules to interface directly with a base operating system 2014 function (e.g., kernel 2028, service 2030, or driver 2032) To be performed. The library 2016 may include a system library 2034 (e.g., a C standard library) capable of providing functions such as a memory allocation function, a string manipulation function, a mathematical function, and the like. The library 2016 may also include a media library (e.g., a library that supports presentation and manipulation of various media formats such as MPREG4, H.264, MP3, AAC, AMR, JPG or PNG) (E.g., OpenGL framework that can be used to render 2D and 3D in graphics content on a display), database libraries (e.g., SQLite that can provide a variety of relational database capabilities), Web libraries (e.g., APIs 2036 such as WebKit (which can provide functions). Library 2016 may also include various other libraries 2038 that provide a number of different APIs to application 2020 and other software components / modules. In one exemplary embodiment, the library 2016 includes an imaging library 2039 that provides image processing or image capture functionality that may be utilized by the custom pattern system 160.

프레임워크(2018)(때때로 미들웨어라고도 함)는 애플리케이션(2020) 또는 다른 소프트웨어 컴포넌트/모듈에 의해 이용될 수 있는 상위 레벨의 공통 인프라스트럭쳐를 제공할 수 있다. 예를 들어, 프레임워크(2018)는, 다양한 그래픽 사용자 인터페이스(GUI) 기능, 상위-레벨 자원 관리, 상위-레벨 위치 서비스 등을 제공할 수 있다. 프레임워크(2018)는 애플리케이션(2020) 또는 다른 소프트웨어 컴포넌트/모듈들에 의해 이용될 수 있는 광범위한 다른 API들을 제공할 있으며, 그 중 일부는 특정한 운영 체제 또는 플랫폼 특유일 수 있다. 한 예시적인 실시예에서, 프레임워크(2018)는 이미지 처리 프레임워크(2022) 및 이미지 포착 프레임워크(2023)를 포함한다. 이미지 처리 프레임워크(2022)는 맞춤형 패턴 시스템(160)의 양태들에서 이용될 수 있는 이미지 처리 기능에 대한 상위 레벨의 지원을 제공할 수 있다. 유사하게, 이미지 포착 프레임워크(2023)는 이미지 포착 및 광학 센서와의 인터페이싱을 위한 상위 레벨의 지원을 제공할 수 있다.The framework 2018 (sometimes referred to as middleware) may provide a high-level common infrastructure that may be utilized by applications 2020 or other software components / modules. For example, the framework 2018 may provide various graphical user interface (GUI) functions, high-level resource management, high-level location services, and the like. The framework 2018 provides a wide variety of other APIs that may be utilized by the application 2020 or other software components / modules, some of which may be specific to a particular operating system or platform. In one exemplary embodiment, the framework 2018 includes an image processing framework 2022 and an image capture framework 2023. The image processing framework 2022 may provide a high level of support for image processing functions that may be utilized in aspects of the custom pattern system 160. [ Similarly, the image capture framework 2023 may provide a high level of support for image capture and interfacing with optical sensors.

애플리케이션(2020)은 내장된 애플리케이션(2040) 또는 제3자 애플리케이션(2042)을 포함한다. 대표적인 내장된 애플리케이션(2040)의 예는, 연락처 애플리케이션, 브라우저 애플리케이션, 북 리더 애플리케이션, 위치 애플리케이션, 미디어 애플리케이션, 메시징 애플리케이션, 또는 게임 애플리케이션을 포함할 수 있지만, 이것으로 제한되지 않는다. 제3자 애플리케이션(2042)은 임의의 내장된 애플리케이션뿐만 아니라 광범위한 다른 애플리케이션을 포함할 수 있다. 특정한 예에서, 제3자 애플리케이션(2042)(예를 들어, 특정한 플랫폼의 벤더 이외의 엔티티에 의해 ANDROID™ 또는 IOS™ 소프트웨어 개발 킷(SDK)을 이용하여 개발된 애플리케이션)은, IOS™, ANDROID™, WINDOWS® Phone 또는 다른 모바일 운영 체제 등의 모바일 운영 체제 상에서 실행되는 모바일 소프트웨어일 수 있다. 이 예에서, 제3자 애플리케이션(2042)은, 여기서 설명된 기능을 가능하게 하기 위해 운영 체제(2014) 등의 모바일 운영 체제에 의해 제공되는 API 호출(2024)을 기동할 수 있다. 한 예시적인 실시예에서, 애플리케이션(220)은 애플리케이션의 일부로서 맞춤형 패턴 시스템(160)을 포함하는 메시징 애플리케이션(2043)을 포함한다. 또 다른 실시예에서, 애플리케이션(220)은 맞춤형 패턴 시스템(160)을 포함하는 독립형 애플리케이션(2045)을 포함한다.The application 2020 includes an embedded application 2040 or a third party application 2042. Exemplary embedded applications 2040 may include, but are not limited to, a contact application, a browser application, a book reader application, a location application, a media application, a messaging application, or a gaming application. Third party application 2042 may include any embedded application as well as a wide variety of other applications. In a particular example, a third party application 2042 (e.g., an application developed using an ANDROID (TM) or IOS (TM) Software Development Kit (SDK) by an entity other than a vendor of a particular platform) , WINDOWS® Phone, or other mobile operating system. In this example, the third party application 2042 may launch an API call 2024 provided by a mobile operating system, such as an operating system 2014, to enable the functionality described herein. In one exemplary embodiment, the application 220 includes a messaging application 2043 that includes a custom pattern system 160 as part of the application. In another embodiment, the application 220 includes a stand alone application 2045 that includes a custom pattern system 160. [

애플리케이션(2020)은, 내장된 운영 체제 기능(예를 들어, 커널(2028), 서비스(2030) 또는 드라이버(2032)), 라이브러리(예를 들어, 시스템(2034), API(2036) 및 기타의 라이브러리(2038)), 시스템의 사용자와 상호작용하는 사용자 인터페이스를 생성하는 프레임워크/미들웨어(2018)를 이용할 수 있다. 대안으로서 또는 추가로, 일부 시스템들에서, 사용자와의 상호작용은 프리젠테이션 계층(2044) 등의 프리젠테이션 계층을 통해 발생할 수 있다. 이들 시스템들에서, 애플리케이션/모듈 "로직"은 사용자와 상호작용하는 애플리케이션/모듈의 양태들로부터 분리될 수 있다.The application 2020 may include one or more of the following: embedded operating system functionality (e.g., kernel 2028, service 2030 or driver 2032), library (e.g., system 2034, API 2036, Library 2038), and framework / middleware 2018 that creates a user interface that interacts with a user of the system. Alternatively, or in addition, in some systems, interaction with a user may occur through a presentation layer, such as the presentation layer 2044. In these systems, the application / module "logic" may be separate from the aspects of the application / module that interact with the user.

일부 소프트웨어 아키텍쳐는 가상 머신을 이용한다. 도 20의 예에서, 이것은 가상 머신(2048)에 의해 예시된다. 가상 머신은, 애플리케이션/모듈이 하드웨어 머신(예를 들어, 도 21의 머신)에서 실행되는 것처럼 실행될 수 있는 소프트웨어 환경을 생성한다. 가상 머신은 호스트 운영 체제(도 21의 운영 체제(2014))에 의해 호스팅되며, 통상적으로, 항상은 아니지만, 호스트 머신 운영 체제(즉, 운영 체제(2014))와의 인터페이싱 할뿐만 아니라 가상 머신의 동작을 관리하는 가상 머신 모니터(2046)를 가진다. 소프트웨어 아키텍쳐는, 운영 체제(2050), 라이브러리(2052), 프레임워크/미들웨어(2054), 애플리케이션(2056) 또는 프리젠테이션 계층(2058) 등의 가상 머신 내에서 실행된다. 가상 머신(2048) 내에서 실행되는 이러한 소프트웨어 아키텍쳐의 계층들은 앞서 설명된 대응하는 계층들과 동일할 수도 있고 상이할 수도 있다.Some software architectures use virtual machines. In the example of FIG. 20, this is illustrated by the virtual machine 2048. The virtual machine creates a software environment in which the application / module can be executed as it is executed in a hardware machine (e.g., the machine of FIG. 21). The virtual machine is hosted by a host operating system (the operating system 2014 of FIG. 21) and is typically, but not always, interfaced with the host machine operating system (i.e., the operating system 2014) And a virtual machine monitor 2046 which manages the virtual machine monitor 2046. The software architecture is implemented within a virtual machine such as an operating system 2050, a library 2052, a framework / middleware 2054, an application 2056, or a presentation layer 2058. The layers of this software architecture that run within the virtual machine 2048 may be the same or different from the corresponding layers described above.

도 21은, 머신-판독가능한 매체(예를 들어, 머신-판독가능한 스토리지 매체)로부터 명령어들을 판독하여 여기서 논의된 방법론들 중 임의의 하나 이상을 수행할 수 있는, 일부 예시적인 실시예에 따른 머신(2100)의 컴포넌트들을 나타내는 블록도이다. 구체적으로는, 도 21은 예시적인 형태의 컴퓨터 시스템으로 된 머신(2100)의 개략도를 도시하며, 머신 내부에서, 머신(2100)으로 하여금 여기서 논의된 방법론들 중 임의의 하나 이상을 수행하게 하는 명령어(2116)(예를 들어, 소프트웨어, 프로그램, 애플리케이션, 애플릿, 앱 또는 기타의 실행가능한 코드)가 실행될 수 있다. 예를 들어, 명령어는 머신으로 하여금 도 5, 6, 8, 10, 13 및 17의 흐름도를 실행하게 할 수 있다. 추가로 또는 대안으로서, 명령어는, 도 2의 통신 모듈(210), 프리젠테이션 모듈(220), 파인더 모듈(230), 정렬 모듈(240), 디코더 모듈(250), 동작 모듈(260) 또는 인코더 모듈(270) 등을 구현할 수 있다. 명령어들은, 일반적인 비프로그램된 머신을, 설명되고 예시된 기능들을 설명된 방식으로 수행하도록 프로그램된 특정한 머신으로 변환한다. 대안적인 실시예에서, 머신(2100)은 독립형 디바이스로서 동작하거나 다른 머신에 결합(예를 들어, 네트워킹)될 수 있다. 네트워킹된 배치에서, 머신(2100)은 서버-클라이언트 네트워크 환경에서 서버 머신 또는 클라이언트 머신의 용량에서 동작하거나, 피어-투-피어(또는 분산형) 네트워크 환경에서 피어 머신으로서 동작할 수 있다. 머신(2100)은, 서버 컴퓨터, 클라이언트 컴퓨터, 개인용 컴퓨터(PC), 태블릿 컴퓨터, 랩탑 컴퓨터, 넷북, 셋탑 박스(STB), PDA(personal digital assistant), 엔터테인먼트 미디어 시스템, 셀룰러 전화, 스마트 폰, 모바일 디바이스, 착용형 디바이스(예를 들어, 스마트 시계), 스마트 홈 디바이스(예를 들어, 스마트 어플라이언스), 기타의 스마트 디바이스, 웹 어플라이언스, 네트워크 라우터, 네트워크 스위치, 네트워크 브릿지, 또는 머신(2100)에 의해 취해질 동작들을 명시하는 명령어(2116)들을 순차적으로 또는 기타의 방식으로 실행할 수 있는 임의의 머신을 포함할 수 있지만, 이것으로 제한되지 않는다. 또한, 단 하나의 머신(2100)이 예시되어 있지만, "머신"이라는 용어는 또한, 여기서 논의된 방법론들 중 임의의 하나 이상을 수행하기 위해 명령어(2116)들을 개별적으로 또는 공동으로 실행하는 머신들의 집합체(2100)를 포함하는 것으로 간주되어야 한다.21 is a block diagram of a machine according to some illustrative embodiments that can read instructions from a machine-readable medium (e.g., a machine-readable storage medium) and perform any one or more of the methodologies discussed herein. 0.0 > 2100 < / RTI > 21 illustrates a schematic diagram of a machine 2100 in an exemplary form of a computer system and includes, within a machine, instructions for causing machine 2100 to perform any one or more of the methodologies discussed herein (E.g., software, program, application, applet, app or other executable code) may be executed. For example, the instructions may cause the machine to execute the flowcharts of FIGS. 5, 6, 8, 10, 13, and 17. Additionally or alternatively, the instructions may include the communication module 210, the presentation module 220, the finder module 230, the alignment module 240, the decoder module 250, the operation module 260, Module 270 or the like. The instructions convert a generic, non-programmed machine to a specific machine programmed to perform the described and illustrated functions in the manner described. In an alternative embodiment, the machine 2100 may operate as a standalone device or may be coupled (e.g., networked) to another machine. In a networked deployment, the machine 2100 may operate in the capacity of a server machine or client machine in a server-client network environment, or may operate as a peer machine in a peer-to-peer (or distributed) network environment. The machine 2100 may be a server computer, a client computer, a personal computer (PC), a tablet computer, a laptop computer, a netbook, a set top box (STB), a personal digital assistant (PDA), an entertainment media system, Devices, worn devices (e.g., smart clocks), smart home devices (e.g., smart appliances), other smart devices, web appliances, network routers, network switches, network bridges, or machines 2100 But is not limited to, any machine capable of executing instructions 2116 that specify actions to be taken in a sequential or other manner. Also, while only one machine 2100 is illustrated, the term "machine" may also be used to refer to a machine 2100 that executes instructions 2116 individually or collectively to perform any one or more of the methodologies discussed herein Aggregate < / RTI > (2100).

머신(2100)은, 버스(2102) 등을 통해 서로 통신하도록 구성될 수 있는 프로세서(2110), 메모리/스토리지(2130) 및 I/O 컴포넌트(2150)를 포함할 수 있다. 한 예시적인 실시예에서, 프로세서(2110)(예를 들어, 중앙 처리 유닛(CPU), RISC(Reduced Instruction Set Computing) 프로세서, CISC(Complex Instruction Set Computing) 프로세서, GPU(Graphics Processing Unit), 디지털 신호 프로세서(DSP; Digital Signal Processor), 주문형 집적 회로(ASIC; Application Specific Integrated Circuit), 무선 주파수 집적 회로(RFIC), 또 다른 프로세서, 또는 이들의 임의의 적절한 조합)는, 예를 들어, 명령어(2116)를 실행할 수 있는 프로세서(2112) 및 프로세서(2114)를 포함할 수 있다. "프로세서"라는 용어는, 명령어들을 동시에 실행할 수 있는 2개 이상의 독립된 프로세서(때때로 "코어"라고도 함)를 포함할 수 있는 멀티-코어 프로세서를 포함하는 것을 의도한다. 도 21은 복수의 프로세서를 도시하지만, 머신(2100)은 단일 코어를 갖는 단일 프로세서, 다중 코어를 갖는 단일 프로세서(예를 들어, 멀티-코어 프로세서), 단일 코어를 갖는 다중 프로세서, 다중 코어를 갖는 다중 프로세서, 또는 이들의 임의의 조합을 포함할 수 있다.The machine 2100 may include a processor 2110, a memory / storage 2130 and an I / O component 2150, which may be configured to communicate with one another via a bus 2102 or the like. In an exemplary embodiment, a processor 2110 (e.g., a central processing unit (CPU), a Reduced Instruction Set Computing (RISC) processor, a Complex Instruction Set Computing (CISC) processor, a Graphics Processing Unit A digital signal processor (DSP), an application specific integrated circuit (ASIC), a radio frequency integrated circuit (RFIC), another processor, or any suitable combination thereof) A processor 2112 and a processor 2114 that are capable of executing instructions (not shown). The term "processor" is intended to include a multi-core processor that may include two or more independent processors (sometimes also referred to as "cores ") capable of executing instructions simultaneously. 21 illustrates a plurality of processors, the machine 2100 may be implemented as a single processor with a single core, a single processor (e.g., a multi-core processor) with multiple cores, multiple processors with a single core, Multiple processors, or any combination thereof.

메모리/스토리지(2130)는, 메인 메모리 또는 기타의 메모리 스토리지 등의 메모리(2132), 및 스토리지 유닛(2136)을 포함할 수 있고, 양쪽 모두는 버스(2102) 등을 통해 프로세서(2110)에 액세스가능하다. 스토리지 유닛(2136) 및 메모리(2132)는, 여기서 설명된 방법론들 또는 기능들 중 임의의 하나 이상을 구현하는 명령어(2116)들을 저장할 수 있다. 명령어(2116)들은 또한, 머신(2100)에 의한 그 실행 동안에, 완전히 또는 부분적으로, 메모리(2132) 내에, 스토리지 유닛(2136) 내에, 프로세서(2110)들 중 적어도 하나 내에(예를 들어, 프로세서의 캐시 메모리 내에), 또는 이들의 임의의 적절한 조합으로 존재할 수 있다. 따라서, 메모리(2132), 스토리지 유닛(2136), 및 프로세서(2110)의 메모리는 머신-판독가능한 매체의 예이다.The memory / storage 2130 may include a memory 2132, such as main memory or other memory storage, and a storage unit 2136, both of which may access the processor 2110 through a bus 2102, It is possible. Storage unit 2136 and memory 2132 may store instructions 2116 that implement any one or more of the methodologies or functions described herein. The instructions 2116 may also be stored in the memory 2132, in the storage unit 2136, in at least one of the processors 2110 (e.g., within the processor 2110), in whole or in part, during its execution by the machine 2100 Of cache memory), or any suitable combination thereof. Thus, the memory 2132, the storage unit 2136, and the memory of the processor 2110 are examples of machine-readable media.

본 명세서에 사용될 때, 용어 "머신-판독가능한 매체"란, 명령어 및 데이터를 일시적으로 또는 영구적으로 저장할 수 있는 디바이스를 의미하며, 랜덤 액세스 메모리(RAM), 판독 전용 메모리(ROM), 버퍼 메모리, 플래시 메모리, 광학 매체, 자기 매체, 캐시 메모리, 다른 타입의 스토리지(예를 들어, 소거가능하고 프로그램가능한 판독 전용 메모리(EEPROM)), 또는 이들의 임의의 적절한 조합을 포함할 수 있지만, 이것으로 제한되는 것은 아니다. "머신-판독가능한 매체"라는 용어는, 명령어(2116)를 저장할 수 있는 단일의 매체 또는 복수의 매체(예를 들어, 중앙집중형 또는 분산형 데이터베이스, 및/또는 연관된 캐시 및 서버)를 포함하는 것으로 간주되어야 한다. "머신-판독가능한 매체"라는 용어는 또한, 명령어들이, 머신(2100)의 하나 이상의 프로세서들(예를 들어, 프로세서들(2110))에 의해 실행될 때, 머신(2100)으로 하여금 여기서 설명된 방법론들 중 임의의 하나 이상을 수행하게 하도록, 머신(예를 들어, 머신(2100))에 의한 실행을 위한 명령어(예를 들어, 명령어(2116))를 저장할 수 있는 임의의 매체 또는 복수의 매체들의 조합을 포함하는 것으로 간주되어야 한다. 따라서, "머신-판독가능한 매체"란, 단일 스토리지 장치 또는 디바이스뿐만 아니라, 복수의 스토리지 장치 또는 디바이스를 포함하는 "클라우드-기반" 스토리지 시스템 또는 스토리지 네트워크를 말한다.As used herein, the term "machine-readable medium" means a device that is capable of temporarily or permanently storing instructions and data, including random access memory (RAM), read only memory (ROM) Flash memory, optical media, magnetic media, cache memory, other types of storage (e.g., erasable programmable read only memory (EEPROM)), or any suitable combination thereof, It is not. The term "machine-readable medium" refers to a medium or medium that includes a single medium or a plurality of media (e.g., a centralized or distributed database, and / or associated cache and server) Should be considered. The term "machine-readable medium" also refers to a medium in which instructions, when executed by one or more processors (e.g., processors 2110) of the machine 2100, cause the machine 2100 to perform, (E.g., instructions 2116) for execution by a machine (e.g., machine 2100) to cause the processor to perform any one or more of the following: Should be considered to include combinations. Thus, "machine-readable medium" refers to a "cloud-based" storage system or storage network that includes a plurality of storage devices or devices, as well as a single storage device or device.

I/O 컴포넌트(2150)는, 입력을 수신하고, 출력을 제공하며, 출력을 생성하고, 정보를 전송하고, 정보를 교환하며, 측정값을 포착하는 등을 수행하는 다양한 컴포넌트를 포함할 수 있다. 특정한 머신에 포함되는 구체적인 I/O 컴포넌트(2150)는 머신의 타입에 의존할 것이다. 예를 들어, 모바일 전화 등의 휴대형 머신은 터치 입력 디바이스 또는 기타의 이러한 입력 메커니즘을 포함할 수 있는 반면, 헤드리스 서버 머신(headless server machine)은 이러한 터치 입력 디바이스를 포함하지 않을 것이다. I/O 컴포넌트(2150)는 도 21에 도시되지 않은 많은 다른 컴포넌트를 포함할 수 있다는 것을 이해할 것이다. I/O 컴포넌트(2150)는 단지 이하의 논의를 간소화하기 위해 기능성에 따라 그룹화되어 있고, 이러한 그룹화는 어떠한 방식으로든 제한하는 것이 아니다. 다양한 예시적인 실시예에서, I/O 컴포넌트(2150)는 출력 컴포넌트(2152) 및 입력 컴포넌트(2154)를 포함할 수 있다. 출력 컴포넌트(2152)는, 시각적 컴포넌트(예를 들어, 플라즈마 디스플레이 패널(PDP), 발광 다이오드(LED) 디스플레이, 액정 디스플레이(LCD), 프로젝터, 또는 CRT(cathode ray tube) 등의 디스플레이), 음향 컴포넌트(예를 들어, 스피커), 햅틱 컴포넌트(예를 들어, 진동 모터, 저항 메커니즘), 기타의 신호 생성기 등을 포함할 수 있다. 입력 컴포넌트(2154)는, 영숫자 입력 컴포넌트(예를 들어, 키보드, 영숫자 입력을 수신하도록 구성된 터치 스크린, 사진-광학 키보드, 또는 기타의 영숫자 입력 컴포넌트), 포인트 기반 입력 컴포넌트(예를 들어, 마우스, 터치패드, 트랙볼, 조이스틱, 움직임 센서 또는 다른 포인팅 도구), 촉각 입력 컴포넌트(예를 들어, 물리적 버턴, 터치 또는 터치 제스쳐의 위치 및 힘을 제공하는 터치 스크린, 또는 기타의 촉각 입력 컴포넌트), 오디오 입력 컴포넌트(예를 들어, 마이크로폰) 등을 포함한다.I / O component 2150 may include various components that perform the functions of receiving inputs, providing outputs, generating outputs, transmitting information, exchanging information, capturing measurements, etc. . The specific I / O component 2150 included in the particular machine will depend on the type of machine. For example, a portable machine, such as a mobile phone, may include a touch input device or other such input mechanism, while a headless server machine will not include such a touch input device. It will be appreciated that I / O component 2150 may include many other components not shown in FIG. I / O components 2150 are grouped according to functionality only to simplify the discussion below, and this grouping is not limiting in any way. In various exemplary embodiments, I / O component 2150 may include an output component 2152 and an input component 2154. The output component 2152 may be a visual component such as a display such as a plasma display panel (PDP), a light emitting diode (LED) display, a liquid crystal display (LCD), a projector, or a cathode ray tube (CRT) (E.g., speakers), haptic components (e.g., vibration motors, resistance mechanisms), other signal generators, and the like. The input component 2154 may include an alphanumeric input component (e.g., a keyboard, a touch screen configured to receive alphanumeric input, a photo-optical keyboard or other alphanumeric input component), a point-based input component (E.g., a touch screen, or other tactile input component that provides the location and force of a physical button, touch or touch gesture), audio input (e.g., a touchpad, trackball, joystick, motion sensor or other pointing tool) Components (e. G., Microphones), and the like.

추가의 예시적인 실시예들에서, I/O 컴포넌트(2150)는, 특히, 바이오메트릭 컴포넌트(2156), 움직임 컴포넌트(2158), 환경 컴포넌트(2160), 또는 위치 컴포넌트(2162)를 포함할 수 있다. 예를 들어, 바이오메트릭 컴포넌트(2156)는, 표현(예를 들어, 손 표현, 얼굴 표정, 음성 표현, 몸짓, 또는 눈 추적)을 검출하고, 생체신호(예를 들어, 혈압, 심박수, 체온, 땀 또는 뇌파)를 측정하고, 사람을 식별(예를 들어, 음성 식별, 망막 식별, 얼굴 식별, 지문 식별, 또는 뇌파계 기반 식별)하는 컴포넌트들을 포함할 수 있다. 움직임 컴포넌트(2158)는, 가속도 센서 컴포넌트(예를 들어, 가속도계), 중력 센서 컴포넌트, 회전 센서 컴포넌트(예를 들어, 자이로스코프) 등을 포함할 수 있다. 환경 컴포넌트(2160)는, 예를 들어, 조명 센서 컴포넌트(예를 들어, 광도계), 온도 센서 컴포넌트(예를 들어, 주변 온도를 검출하는 하나 이상의 온도계), 습도 센서 컴포넌트, 압력 센서 컴포넌트(예를 들어, 기압계), 음향 센서 컴포넌트(예를 들어, 배경 잡음을 검출하는 하나 이상의 마이크로폰), 근접 센서 컴포넌트(예를 들어, 근처의 물체를 검출하는 적외선 센서), 개스 센서 컴포넌트(예를 들어, 머신 후각 검출 센서, 안전을 위해 위험한 개스의 농도를 검출하거나 대기 중의 오염 물질을 측정하는 개스 검출 센서), 또는 주변의 물리적 환경에 대응하는 표시, 측정치, 또는 신호를 제공할 수 있는 기타의 컴포넌트들을 포함할 수 있다. 위치 컴포넌트(2162)는, 위치 센서 컴포넌트(예를 들어, GPS(Global Positioning System) 수신기 컴포넌트), 고도 센서 컴포넌트(고도가 도출될 수 있는 기압을 검출하는 고도계 또는 기압계), 배향 센서 컴포넌트(예를 들어, 자력계) 등을 포함할 수 있다.In further exemplary embodiments, the I / O component 2150 may include, among other things, a biometric component 2156, a motion component 2158, an environmental component 2160, or a location component 2162 . For example, the biometric component 2156 may be configured to detect an expression (e.g., a hand expression, a facial expression, a voice expression, a gesture, or an eye trace) and generate a biometric signal (e.g., blood pressure, heart rate, Sweat or brain wave) and identify the person (e.g., voice identification, retina identification, face identification, fingerprint identification, or brain-based based identification). Motion component 2158 may include an acceleration sensor component (e.g., an accelerometer), a gravity sensor component, a rotation sensor component (e.g., a gyroscope), and the like. The environmental component 2160 may include, for example, a light sensor component (e.g., a photometer), a temperature sensor component (e.g., one or more thermometers that detect ambient temperature), a humidity sensor component, (E.g., barometers), acoustic sensor components (e.g., one or more microphones that detect background noise), proximity sensor components (e.g., infrared sensors that detect nearby objects), gas sensor components A smell detection sensor, a gas detection sensor that detects the concentration of dangerous gases for safety or measures contaminants in the atmosphere), or other components that can provide indicia, measurements, or signals corresponding to the surrounding physical environment can do. The position component 2162 may include a position sensor component (e.g., a Global Positioning System (GPS) receiver component), an altitude sensor component (an altimeter or barometer that detects the altitude at which altitude can be derived), an orientation sensor component For example, a magnetometer), and the like.

통신은 다양한 기술을 이용하여 구현될 수 있다. I/O 컴포넌트(2150)는, 머신(2100)을 각각 결합(2182) 및 결합(2172)을 통해 네트워크(2180) 또는 디바이스(2170)에 결합하도록 동작가능한 통신 컴포넌트(2164)를 포함할 수 있다. 예를 들어, 통신 컴포넌트(2164)는, 네트워크 인터페이스 컴포넌트, 또는 네트워크(2180)와 인터페이스하기에 적합한 다른 디바이스를 포함한다. 추가 예에서, 통신 컴포넌트(2164)는, 유선 통신 컴포넌트, 무선 통신 컴포넌트, 셀룰러 통신 컴포넌트, 근접장 통신(NFC) 컴포넌트, BLUETOOTH® 컴포넌트(예를 들어, BLUETOOTH® Low Energy), WI-FI® 컴포넌트, 및 다른 양태를 통해 통신을 제공하는 기타의 통신 컴포넌트를 포함한다. 디바이스(2170)는, 또 다른 머신 또는 임의의 다양한 주변 디바이스(예를 들어, USB(Universal Serial Bus)를 통해 결합된 주변 디바이스)일 수 있다.Communication can be implemented using various technologies. The I / O component 2150 may include a communication component 2164 operable to couple the machine 2100 to the network 2180 or device 2170 via a coupling 2182 and a coupling 2172, respectively . For example, communication component 2164 includes a network interface component, or other device suitable for interfacing with network 2180. In a further example, the communication component 2164 may be a wired communication component, a wireless communication component, a cellular communication component, a near field communication (NFC) component, a BLUETOOTH® component (eg, BLUETOOTH® Low Energy), a WI- And other communication components that provide communication over other aspects. The device 2170 may be another machine or any of a variety of peripheral devices (e.g., a peripheral device coupled via a Universal Serial Bus (USB)).

게다가, 통신 컴포넌트(2164)는 식별자를 검출하거나 식별자를 검출하도록 동작가능한 컴포넌트를 포함할 수 있다. 예를 들어, 통신 컴포넌트(2164)는, 무선 주파수 식별(RFID) 태그 판독기 컴포넌트, NFC 스마트 태그 검출 컴포넌트, 광학 판독기 컴포넌트(예를 들어, 범용 제품 코드(UPC) 바코드 등의 일차원 바코드, QR(Quick Response) 코드, Aztec 코드, Data Matrix, Dataglyph, MaxiCode, PDF417, Ultra 코드, UCC RSS(Uniform Commercial Code Reduced Space Symbology)-2D 바 코드, 및 기타의 광학 코드 등의 다차원 바코드를 검출하는 광학 센서), 음향 검출 컴포넌트(예를 들어, 태깅된 오디오 신호를 식별하는 마이크로폰), 또는 이들의 임의의 적절한 조합을 포함할 수 있다. 또한, 인터넷 프로토콜(IP) 지오-로케이션을 통한 위치, WI-FI® 신호 삼각측량을 통한 위치, 특정한 위치를 나타낼 수 있는 BLUETOOTH® 또는 NFC 비컨 신호 검출을 통한 위치 등의 다양한 정보가 통신 컴포넌트(2164)를 통해 도출될 수 있다.In addition, the communication component 2164 may comprise a component operable to detect an identifier or to detect an identifier. For example, the communication component 2164 may be a one-dimensional barcode such as a radio frequency identification (RFID) tag reader component, an NFC smart tag detection component, an optical reader component (e.g., Universal Product Code An optical sensor for detecting a multi-dimensional barcode such as a response code, an Aztec code, a Data Matrix, a Dataglyph, a MaxiCode, a PDF417, an Ultra code, a UCC RSS (Uniform Commercial Code Reduced Space Symbology) Sound detection components (e. G., A microphone that identifies the tagged audio signal), or any suitable combination thereof. In addition, various information such as the location through internet protocol (IP) geo-location, the position through WI-FI signal triangulation, the location through BLUETOOTH or NFC beacon signal detection which can indicate a specific location, ). ≪ / RTI >

다양한 예시적인 실시예에서, 네트워크(2180)의 하나 이상의 부분은, 애드혹 네트워크, 인트라넷, 엑스트라넷, 가상 사설망(VPN), 근거리 통신망(LAN), 무선 LAN(WLAN), 광역 네트워크(WAN), 무선 WAN(WWAN), 도시권 통신망(MAN; Metropolitan Area Network), 인터넷, 인터넷의 일부, PSTN(Public Switched Telephone Network)의 일부, POTS(plain old telephone service) 네트워크, 셀룰러 전화 네트워크, 무선 네트워크, WI-FI® 네트워크, 또 다른 타입의 네트워크, 또는 2개 이상의 이러한 네트워크들의 조합일 수 있다. 예를 들어, 네트워크(2180) 또는 네트워크(2180)의 일부는 무선 또는 셀룰러 네트워크를 포함할 수 있고, 결합(2182)은 CDMA(Code Division Multiple Access) 접속, GSM(Global System for Mobile communications) 접속, 또는 다른 타입의 셀룰러 또는 무선 결합을 포함할 수 있다. 이 예에서, 결합(2182)은, 1xRTT(Single Carrier Radio Transmission Technology), EVDO(Evolution-Data Optimized) 기술, GPRS(General Packet Radio Service) 기술, EDGE(Enhanced Data rates for GSM Evolution) 기술, 3G, 4G(fourth generation wireless) 네트워크, UMTS(Universal Mobile Telecommunications System), HSPA(High Speed Packet Access), WiMAX(Worldwide Interoperability for Microwave Access), LTE(Long Term Evolution) 표준, 다양한 표준-설정 기구에 의해 정의된 기타의 것들을 포함한 3GPP(third Generation Partnership Project), 기타의 장거리 프로토콜, 또는 기타의 데이터 전송 기술 등의, 다양한 타입의 데이터 전송 기술들 중 임의의 것을 구현할 수 있다.In various exemplary embodiments, one or more portions of the network 2180 may include one or more of an ad hoc network, an intranet, an extranet, a virtual private network (VPN), a local area network (LAN), a wireless local area network (WLAN) A part of a public switched telephone network (PSTN), a plain old telephone service (POTS) network, a cellular telephone network, a wireless network, a WI-FI (Public Switched Telephone Network) Network, another type of network, or a combination of two or more such networks. For example, a portion of network 2180 or network 2180 may include a wireless or cellular network, and combination 2182 may include a Code Division Multiple Access (CDMA) connection, a Global System for Mobile communications (GSM) Or other types of cellular or wireless coupling. In this example, the combination 2182 may include one or more of the following: 1xRTT, Evolution-Data Optimized (EVDO), General Packet Radio Service (GPRS), Enhanced Data Rates for GSM Evolution (EDGE) (LTE) standard defined by various standard-setting mechanisms, such as a 4G (fourth generation wireless) network, a Universal Mobile Telecommunications System (UMTS), a High Speed Packet Access (HSPA), a Worldwide Interoperability for Microwave Access Such as third generation partnership projects (3GPP), including, among others, other long distance protocols, or other data transmission techniques.

명령어(2116)들은, 네트워크 인터페이스 디바이스(예를 들어, 통신 컴포넌트(2164)에 포함된 네트워크 인터페이스 컴포넌트)를 통해 전송 매체를 이용하여 및 다수의 널리 공지된 프로토콜들 중 임의의 하나(예를 들어, 하이퍼텍스트 전송 프로토콜(HTTP))를 이용하여 네트워크(2180)를 통해 전송되거나 수신될 수 있다. 유사하게, 명령어(2116)들은 디바이스(2170)에 대한 결합(2172)(예를 들어, 피어-투-피어 결합)을 통해 전송 매체를 이용하여 전송되거나 수신될 수 있다. "전송 매체"라는 용어는, 머신(2100)에 의한 실행을 위한 명령어(2116)를 저장, 인코딩 또는 운반할 수 있고, 이러한 소프트웨어의 전달을 가능케하는 디지털 또는 아날로그 통신 신호 또는 기타의 무형 매체를 포함하는 임의의 무형의 매체를 포함하는 것으로 간주된다. 전송 매체는 머신-판독가능한 매체의 한 실시예이다.Instructions 2116 may be transmitted using a transmission medium through a network interface device (e.g., a network interface component included in communication component 2164) and any one of a number of well known protocols (e.g., May be transmitted or received over the network 2180 using a hypertext transfer protocol (" HTTP "). Similarly, the instructions 2116 may be transmitted or received using a transmission medium via a coupling 2172 (e.g., peer-to-peer coupling) to the device 2170. The term "transmission medium" includes digital or analog communication signals or other intangible media that can store, encode, or transport instructions 2116 for execution by the machine 2100 and enable the transmission of such software Or any other type of medium. The transmission medium is one embodiment of a machine-readable medium.

이하의 번호 매겨진 예들은 실시예들이다.The following numbered examples are embodiments.

1. 시스템으로서,1. As a system,

맞춤형 그래픽을 위한 기준 이미지의 기준 이미지 데이터를 수신하는 통신 모듈;A communication module for receiving reference image data of a reference image for a customized graphic;

상기 기준 이미지 데이터로부터 상기 맞춤형 그래픽의 기준 형상 피쳐 ―상기 기준 형상 피쳐는 상기 맞춤형 그래픽의 정체성을 나타냄― 를 결정하는 파인더 모듈;A finder module for determining from the reference image data the reference shape feature of the customized graphic, the reference shape feature representing an identity of the customized graphic;

형상 피쳐 규칙 및 상기 맞춤형 그래픽의 기준 형상 피쳐를 저장하도록 구성된 메모리;A memory configured to store geometry feature rules and reference geometry features of the custom graphics;

상기 메모리에 결합되고, 상기 통신 모듈을 포함하는 하드웨어 프로세서A hardware processor coupled to the memory,

를 포함하고,Lt; / RTI >

상기 통신 모듈은 또한, 클라이언트 디바이스로부터 이미지의 이미지 데이터를 수신하도록 구성되고;The communication module is further configured to receive image data of an image from a client device;

상기 파인더 모듈은 또한 :The finder module also includes:

상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하고;Extract a candidate shape feature of the image from the image data;

상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족한다고 결정하며;Determine that the candidate shape feature satisfies the shape feature rule;

상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족하는 것에 응답하여, 상기 후보 형상 피쳐와 상기 맞춤형 그래픽의 상기 기준 형상 피쳐의 비교에 기초하여 상기 이미지에서 상기 맞춤형 그래픽을 식별하도록 구성되고; 및Identify the custom graphic in the image based on a comparison of the candidate shape feature and the reference shape feature of the custom graphic in response to the candidate shape feature satisfying the shape feature rule; And

상기 파인더 모듈이 상기 맞춤형 그래픽을 식별하는 것에 응답하여, 상기 이미지에 포함된 데이터를 나타내는 마킹을 검출함으로써 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하도록 구성된 디코더 모듈A decoder module configured to decode data encoded within a portion of the image from the image data by detecting markings indicative of data contained in the image, in response to the finder module identifying the customized graphics;

을 포함하는 시스템.≪ / RTI >

2. 예1에 있어서, 상기 파인더 모듈은 또한 :2. The method of embodiment 1 wherein said finder module further comprises:

상기 이미지 데이터로부터 상기 후보 형상 피쳐의 면적 값 ―상기 면적 값은 상기 면적 값을 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨― 을 계산하고;Calculating an area value of the candidate shape feature from the image data, the area value being computed in conjunction with another candidate shape feature to scale the area value;

상기 면적 값을 상기 맞춤형 그래픽의 기준 면적 값과 비교함으로써 상기 후보 형상 피쳐에 대한 면적 점수를 결정하며;Determine an area score for the candidate shape feature by comparing the area value with a reference area value of the custom graphics;

임계값을 초과하는 상기 면적 점수에 기초하여 상기 후보 형상 피쳐가 면적 규칙 ―상기 형상 피쳐 규칙은 상기 면적 규칙을 포함함― 을 만족한다고 결정Based on the area score exceeding the threshold, determines that the candidate shape feature satisfies an area rule - the shape feature rule includes the area rule

하도록 구성된, 시스템.≪ / RTI >

3. 컴퓨터 구현된 방법으로서,3. A computer-implemented method,

맞춤형 심볼에 대한 기준 이미지의 기준 이미지 데이터를 수신하는 단계;Receiving reference image data of a reference image for a custom symbol;

상기 기준 이미지 데이터로부터 상기 기준 이미지의 기준 형상 피쳐 ―상기 기준 형상 피쳐는 상기 맞춤형 심볼의 정체성을 나타냄― 를 결정하는 단계;Determining a reference shape feature of the reference image from the reference image data, the reference shape feature representing an identity of the customized symbol;

사용자 디바이스로부터 이미지의 이미지 데이터를 수신하는 단계;Receiving image data of an image from a user device;

상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하는 단계;Extracting a candidate shape feature of the image from the image data;

상기 후보 형상 피쳐가 형상 피쳐 기준을 만족한다고 결정하는 단계;Determining that the candidate shape feature satisfies a shape feature criterion;

상기 후보 형상 피쳐가 상기 형상 피쳐 기준을 만족하는 것에 응답하여, 상기 후보 형상 피쳐를 상기 맞춤형 심볼의 상기 기준 형상 피쳐와 비교함으로써 상기 이미지에서 상기 맞춤형 심볼을 식별하는 단계;Identifying the customizable symbol in the image by comparing the candidate shape feature with the reference shape feature of the customizable symbol in response to the candidate shape feature satisfying the feature feature criteria;

상기 맞춤형 심볼을 식별하는 것에 응답하여, 상기 이미지 데이터로부터 상기 이미지 내의 상기 맞춤형 심볼의 기하학적 속성을 추출하는 단계; 및Extracting a geometric attribute of the customizable symbol in the image from the image data in response to identifying the customizable symbol; And

상기 이미지 내의 상기 맞춤형 심볼의 상기 기하학적 속성을 이용하여 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하는 단계Decoding the data encoded within a portion of the image from the image data using the geometric property of the custom symbol in the image

를 포함하는 방법.≪ / RTI >

4. 예3에 있어서,4. In Example 3,

상기 이미지 데이터로부터 상기 후보 형상 피쳐의 크기 근사 ―상기 크기 근사는 상기 크기 근사를 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨― 를 계산하는 단계;Calculating a magnitude approximation of the candidate shape feature from the image data, wherein the magnitude approximation is computed in conjunction with another candidate shape feature to scale the magnitude approximation;

상기 크기 근사를 상기 맞춤형 심볼의 기준 크기와 비교함으로써 상기 후보 형상 피쳐에 대한 크기 점수를 결정하는 단계; 및Determining a size score for the candidate shape feature by comparing the size approximation with a reference size of the custom symbol; And

임계값을 초과하는 상기 크기 점수에 기초하여 상기 후보 형상 피쳐가 크기 기준 ―상기 형상 피쳐 기준은 상기 크기 기준을 포함함― 을 만족한다고 결정하는 단계Determining that the candidate shape feature is based on a magnitude criterion and the feature feature criterion comprises the magnitude criterion based on the magnitude score exceeding a threshold value

를 더 포함하는 방법.≪ / RTI >

5. 예3 또는 예4에 있어서,5. In Example 3 or Example 4,

상기 이미지 데이터로부터 상기 후보 형상 피쳐가 폐곡선 ―상기 폐곡선은 특정한 지점에서 시작하여 상기 특정한 지점으로 복귀하는 경로를 가짐으로써 상기 이미지의 일부를 둘러쌈― 을 포함한다고 결정하는 단계; 및Determining from the image data that the candidate shape feature includes a closed curve, the closed curve having a path starting at a particular point and returning to the particular point; And

상기 폐곡선을 포함하는 상기 후보 형상 피쳐에 기초하여 상기 후보 형상 피쳐가 경로 기준 ―상기 형상 피쳐 기준은 상기 경로 기준을 포함함― 을 만족한다고 결정하는 단계Determining that the candidate shape feature is based on the candidate shape feature comprising the closed curve and the shape feature reference comprises the path reference;

를 더 포함하는 방법.≪ / RTI >

6. 예3 내지 예5 중 어느 하나에 있어서, 상기 기하학적 속성은 상기 이미지 내의 상기 맞춤형 심볼의 위치, 스케일, 또는 배향 중 적어도 하나를 포함하는, 방법.6. The method as in any of the embodiments 3-5, wherein the geometric attribute comprises at least one of position, scale, or orientation of the custom symbol in the image.

7. 예3 내지 예6 중 어느 하나에 있어서,7. The process of any of Examples 3 to 6,

상기 이미지 데이터로부터 상기 맞춤형 심볼의 고유 피쳐 ―상기 고유 피쳐는 상기 맞춤형 심볼의 식별을 나타냄― 를 추출하는 단계;Extracting from the image data an intrinsic feature of the custom symbol, the intrinsic feature representing an identification of the custom symbol;

상기 고유 피쳐를 상기 맞춤형 심볼의 기준 고유 피쳐와 비교함으로써 상기 이미지 내의 상기 맞춤형 심볼의 배향을 결정하는 단계; 및Determining an orientation of the custom symbol in the image by comparing the intrinsic feature with a reference intrinsic feature of the custom symbol; And

상기 이미지 내의 상기 맞춤형 심볼의 상기 배향 및 위치를 이용하여 상기 이미지 내에 인코딩된 데이터를 디코딩하는 단계Decoding the encoded data in the image using the orientation and position of the customized symbol in the image

를 더 포함하는 방법.≪ / RTI >

8. 예7에 있어서,8. In Example 7,

상기 이미지 내의 상기 맞춤형 심볼의 고유 지점 ―상기 고유 피쳐는 상기 고유 지점을 포함함― 을 식별하는 단계; 및Identifying an intrinsic point of the custom symbol in the image, the intrinsic feature comprising the intrinsic point; And

상기 이미지 내의 상기 맞춤형 심볼에 관한 상기 고유 지점의 위치를 상기 맞춤형 심볼의 기준 지점의 위치와 비교함으로써 상기 이미지 내의 상기 맞춤형 심볼의 배향을 결정하는 단계Determining an orientation of the custom symbol in the image by comparing a position of the unique point with respect to the custom symbol in the image to a position of a reference point of the custom symbol

를 더 포함하는 방법.≪ / RTI >

9. 예7 또는 예8에 있어서,9. The process according to example 7 or 8,

상기 맞춤형 심볼의 배향에 따라 상기 이미지를 변환함으로써 변환된 이미지를 생성하는 단계; 및Generating a transformed image by transforming the image according to the orientation of the customized symbol; And

상기 변환된 이미지를 이용하여 상기 이미지의 상기 일부 내에 인코딩된 데이터를 디코딩하는 단계Decoding the encoded data within the portion of the image using the transformed image

를 더 포함하는 방법.≪ / RTI >

10. 예9에 있어서,10. The method of claim 9,

상기 변환된 이미지를 이용한 상기 이미지의 상기 일부 내에 인코딩된 데이터의 디코딩 실패를 결정하는 단계;Determining a decoding failure of the encoded data in the portion of the image using the transformed image;

상기 맞춤형 심볼의 상이한 배향에 따라 상기 이미지를 변환함으로써 또 다른 변환된 이미지를 생성하는 단계; 및Generating another transformed image by transforming the image according to a different orientation of the customized symbol; And

상기 또 다른 변환된 이미지를 이용하여 상기 이미지의 상기 일부 내에 인코딩된 데이터를 디코딩하는 단계Decoding the encoded data within the portion of the image using the another transformed image

를 더 포함하는 방법.≪ / RTI >

11. 예3 내지 예10 중 어느 하나에 있어서, 상기 이미지의 상기 일부 내에 인코딩된 데이터는 상기 이미지 내의 상기 맞춤형 심볼에 관해 위치한 복수의 마크들을 이용하여 인코딩되고, 상기 복수의 마크들의 각각의 마크는 데이터 조각을 나타내는, 방법.11. The method as in any of the embodiments 3-10, wherein the data encoded in the portion of the image is encoded using a plurality of marks located relative to the customizable symbol in the image, wherein each mark of the plurality of marks ≪ / RTI >

12. 제3 내지 예11 중 어느 하나에 있어서, 상기 맞춤형 심볼은, 로고, 아이콘, 또는 상표 중 적어도 하나를 포함하는, 방법.12. The method as in any of the embodiments 3-11, wherein the customizable symbol comprises at least one of a logo, an icon, or a trademark.

13. 예3 내지 예12 중 어느 하나에 있어서,13. The process of any of Examples 3 to 12,

상기 사용자 디바이스의 이미지 센서로부터 상기 이미지 데이터를 실시간으로 수신하는 단계를 더 포함하는 방법.And receiving the image data in real time from an image sensor of the user device.

14. 예3 내지 예13 중 어느 하나에 있어서, 상기 맞춤형 심볼의 형상은 적어도 하나의 비대칭성을 포함하는, 방법.14. The method as in any of the embodiments 3-13, wherein the shape of the customizable symbol comprises at least one asymmetry.

15. 예3 내지 예14 중 어느 하나에 있어서,15. The process of any one of Examples 3 to 14,

상기 이미지 내에 인코딩된 데이터를 디코딩하는 것에 응답하여, 상기 이미지로부터 디코딩된 데이터를 이용하여 상기 사용자 디바이스 관해 동작을 수행하는 단계를 더 포함하는 방법.And in response to decoding the encoded data in the image, performing an operation on the user device using the decoded data from the image.

16. 예15에 있어서, 상기 동작은 상기 이미지로부터 디코딩된 데이터에 의해 명시된 동작을 포함하는, 방법.16. The method of embodiment 15, wherein the operation comprises an operation specified by decoded data from the image.

17. 예15 또는 예16에 있어서, 상기 동작은 서버와의 통신없이 수행되는, 방법.17. The method of embodiment 15 or 16 wherein the operation is performed without communication with a server.

18. 예15 내지 예17 중 어느 하나에 있어서, 상기 동작은 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩한 모바일 컴퓨팅 애플리케이션에 전용되는, 방법.18. The method as in any of the embodiments 15-17, wherein the operation is dedicated to mobile computing applications that decoded data encoded within a portion of the image.

19. 머신의 적어도 하나의 프로세서에 의해 실행될 때, 상기 머신으로 하여금 동작들을 수행하게 하는 명령어들을 포함하는 머신-판독가능한 매체로서, 상기 동작들은,19. A machine-readable medium comprising instructions that, when executed by at least one processor of a machine, cause the machine to perform operations,

특정한 디자인에 대한 기준 이미지의 기준 이미지 데이터를 수신하는 단계;Receiving reference image data of a reference image for a particular design;

상기 기준 이미지 데이터로부터 상기 기준 이미지의 기준 형상 피쳐 ―상기 기준 형상 피쳐는 상기 특정한 디자인의 정체성을 나타냄― 를 결정하는 단계;Determining from the reference image data the reference shape feature of the reference image-the reference shape feature-identifies the identity of the particular design;

클라이언트 시스템으로부터 이미지의 이미지 데이터를 수신하는 단계;Receiving image data of an image from a client system;

상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하는 단계;Extracting a candidate shape feature of the image from the image data;

상기 후보 형상 피쳐가 형상 피쳐 규칙을 만족한다고 결정하는 단계;Determining that the candidate shape feature satisfies a shape feature rule;

상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족하는 것에 응답하여, 상기 후보 형상 피쳐를 상기 특정한 디자인의 상기 기준 형상 피쳐와 비교함으로써 상기 이미지에서 상기 특정한 디자인을 식별하는 단계;Identifying the particular design in the image by comparing the candidate shape feature with the reference shape feature of the particular design in response to the candidate shape feature satisfying the shape feature rule;

상기 특정한 디자인을 식별하는 것에 응답하여, 상기 이미지 데이터로부터 상기 이미지 내의 상기 특정한 디자인의 공간적 속성을 추출하는 단계; 및Extracting a spatial attribute of the particular design within the image from the image data in response to identifying the particular design; And

상기 이미지 내의 상기 특정한 디자인의 상기 공간적 속성을 이용하여 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하는 단계Decoding the data encoded within a portion of the image from the image data using the spatial property of the particular design within the image

를 포함하는, 머신-판독가능한 매체.Readable medium.

20. 예19에 있어서, 상기 동작들은,20. The method of embodiment 19,

상기 이미지 데이터로부터 상기 후보 형상 피쳐의 크기 근사 ―상기 크기 근사는 상기 크기 근사를 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨― 를 계산하는 단계;Calculating a magnitude approximation of the candidate shape feature from the image data, wherein the magnitude approximation is computed in conjunction with another candidate shape feature to scale the magnitude approximation;

상기 크기 근사를 상기 특정한 디자인의 기준 크기와 비교함으로써 상기 후보 형상 피쳐에 대한 크기 점수를 결정하는 단계; 및Determining a size score for the candidate shape feature by comparing the size approximation to a reference size of the particular design; And

임계값을 초과하는 상기 크기 점수에 기초하여 상기 후보 형상 피쳐가 크기 규칙 ―상기 형상 피쳐 규칙은 상기 크기 규칙을 포함함― 을 만족한다고 결정하는 단계Determining that the candidate shape feature is based on a size rule that exceeds a threshold value, the shape feature rule includes the size rule,

를 더 포함하는 머신-판독가능한 매체.Readable medium.

21. 컴퓨터의 적어도 하나의 프로세서에 의해 실행될 때, 상기 컴퓨터로 하여금, 예3 내지 예18 중 어느 하나의 방법을 실행하게 하는 명령어들을 포함하는 머신-판독가능한 매체.21. A machine-readable medium comprising instructions, when executed by at least one processor of a computer, to cause the computer to perform the method of any one of Examples 3 to 18.

본 명세서 전체를 통해, 복수의 인스턴스는, 단일 인스턴스로서 설명된 컴포넌트, 동작 또는 구조를 구현할 수 있다. 하나 이상의 방법의 개개의 동작들이 별개의 동작들로서 예시되고 설명되지만, 개개의 동작들 중 하나 이상은 동시에 수행될 수 있고, 동작들이 예시된 순서로 수행될 필요는 없다. 예시적인 구성에서 별개의 컴포넌트들로서 제시된 구조 및 기능은 결합된 구조 또는 컴포넌트로서 구현될 수 있다. 유사하게, 단일 컴포넌트로서 제시된 구조 및 기능은 별개의 컴포넌트들로서 구현될 수 있다. 이들 및 다른 변형, 수정, 추가 및 개선은 본 명세서의 주제의 범위 내에 있다.Throughout this specification, a plurality of instances may implement the described components, acts, or structures as a single instance. While individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and operations need not be performed in the order illustrated. The structures and functions presented as separate components in an exemplary configuration may be implemented as a combined structure or component. Similarly, the structure and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter herein.

비록 본 발명의 주제에 대한 개요가 특정한 예시적인 실시예를 참조하여 설명되었지만, 본 개시내용의 실시예들의 더 넓은 범위를 벗어나지 않으면서 이들 실시예들에 대한 다양한 수정 및 변경이 이루어질 수 있다. 본 발명의 주제의 이러한 실시예들은, 여기서, 사실상 하나보다 많은 발명 또는 발명적 개념이 개시되고 있지만, 본 출원의 범위를 임의의 단일의 개시내용이나 발명적 개념으로 자발적으로 제한하려는 의도없이 단지 편의상 "발명"이라는 용어에 의해, 개별적으로 또는 집합적으로 언급될 수 있다.Although an overview of the subject matter of the present invention has been set forth with reference to specific exemplary embodiments, various modifications and changes may be made to these embodiments without departing from the broader scope of embodiments of the present disclosure. These embodiments of the subject matter of the present invention are hereby incorporated by reference in their entirety for all purposes, without even the intention of voluntarily limiting the scope of the present application to any single disclosure or inventive concept, May be referred to individually or collectively by the term "invention ".

여기서 예시된 실시예들은 본 기술분야의 통상의 기술자가 여기서 개시된 교시를 실시할 수 있게 하도록 충분히 상세하게 설명되었다. 본 개시내용의 범위로부터 벗어나지 않고 구조적 및 논리적 치환과 변경이 이루어질 수 있도록 하는 다른 실시예들이 이용될 수 있고 본 개시내용으로부터 유도될 수 있다. 따라서, 본 상세한 설명은 제한적인 의미로 간주되어서는 안되며, 다양한 실시예들의 범위는 첨부된 청구항들과 이러한 청구항들의 균등물의 전체 범위에 의해서만 정의된다.The embodiments illustrated herein have been described in sufficient detail to enable those of ordinary skill in the art to practice the teachings disclosed herein. Other embodiments may be utilized and derived from the present disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the present disclosure. Accordingly, this description is not to be taken in a limiting sense, and the scope of the various embodiments is defined only by the appended claims and their full scope of equivalents.

본 명세서에서 사용될 때, 용어 "또는"은 포함적 또는 배타적 의미로 해석될 수 있다. 게다가, 본 명세서에서 단일 인스턴스로서 설명된 자원, 동작, 또는 구조에 대해 복수의 인스턴스가 제공될 수 있다. 추가로, 다양한 자원, 동작, 모듈, 엔진 및 데이터 저장소 사이의 경계는 다소 임의적이며, 특정한 동작은 특정한 예시적인 구성의 문맥에서 예시된다. 기능의 다른 할당들을 구상해 볼 수 있고 본 개시내용의 다양한 실시예의 범위 내에 있을 수 있다. 일반적으로, 예시적인 구성에서 별개의 자원으로서 제시된 구조 및 기능은 결합된 구조 또는 자원으로서 구현될 수 있다. 유사하게, 단일 자원으로서 제시된 구조 및 기능은 별개의 자원으로서 구현될 수 있다. 이들 및 다른 변형, 수정, 추가 및 개선은 첨부된 청구항들로 표현되는 본 개시내용의 실시예들의 범위 내에 있다. 따라서, 본 명세서 및 도면은 제한적 의미라기보다는 예시적인 의미로 간주되어야 한다.As used in this specification, the term "or" can be interpreted as inclusive or exclusive. In addition, multiple instances may be provided for a resource, operation, or structure described herein as a single instance. In addition, the boundaries between various resources, operations, modules, engines and data stores are somewhat arbitrary, and the specific operation is illustrated in the context of a particular exemplary configuration. Other assignments of functionality may be envisaged and may be within the scope of various embodiments of the present disclosure. Generally, structures and functions presented as discrete resources in an exemplary configuration may be implemented as a combined structure or resource. Similarly, the structure and function presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within the scope of the embodiments of the present disclosure as expressed in the appended claims. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.

Claims (21)

시스템으로서,
맞춤형 그래픽을 위한 기준 이미지의 기준 이미지 데이터를 수신하는 통신 모듈;
상기 기준 이미지 데이터로부터 상기 맞춤형 그래픽의 기준 형상 피쳐를 결정하는 파인더 모듈 - 상기 기준 형상 피쳐는 상기 맞춤형 그래픽의 정체성(identity)을 나타냄 -;
상기 맞춤형 그래픽의 기준 형상 피쳐 및 형상 피쳐 규칙(shape feature rule)을 저장하도록 구성된 메모리; 및
상기 메모리에 결합되고, 상기 통신 모듈을 포함하는 하드웨어 프로세서
를 포함하고,
상기 통신 모듈은 클라이언트 디바이스로부터 이미지의 이미지 데이터를 수신하도록 추가로 구성되고;
상기 파인더 모듈은 :
상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하고;
상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족한다는 것을 결정하며;
상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족하는 것에 응답하여, 상기 맞춤형 그래픽의 기준 형상 피쳐와 상기 후보 형상 피쳐의 비교에 기초하여 상기 이미지 내의 맞춤형 그래픽을 식별하도록 구성되고; 및
상기 파인더 모듈이 상기 맞춤형 그래픽을 식별하는 것에 응답하여, 상기 이미지에 포함된 데이터를 나타내는 마킹들을 검출함으로써 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하도록 구성된 디코더 모듈
을 포함하는 시스템.
As a system,
A communication module for receiving reference image data of a reference image for a customized graphic;
A finder module for determining a reference shape feature of the customized graphic from the reference image data, the reference shape feature representing an identity of the customized graphic;
A memory configured to store a shape feature feature and a shape feature rule of the custom graphics; And
A hardware processor coupled to the memory,
Lt; / RTI >
The communication module being further configured to receive image data of an image from a client device;
The finder module comprises:
Extract a candidate shape feature of the image from the image data;
Determine that the candidate shape feature satisfies the shape feature rule;
Identify a custom graphic in the image based on a comparison of the candidate shape feature with the reference shape feature of the custom graphic in response to the candidate shape feature satisfying the shape feature rule; And
A decoder module configured to decode data encoded within a portion of the image from the image data by detecting markings indicative of data contained in the image in response to the finder module identifying the customized graphics;
≪ / RTI >
제1항에 있어서, 상기 파인더 모듈은:
상기 이미지 데이터로부터 상기 후보 형상 피쳐의 면적 값을 계산하고 - 상기 면적 값은 상기 면적 값을 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨 -;
상기 면적 값을 상기 맞춤형 그래픽의 기준 면적 값과 비교함으로써 상기 후보 형상 피쳐에 대한 면적 점수를 결정하며;
임계값을 초과하는 상기 면적 점수에 기초하여 상기 후보 형상 피쳐가 면적 규칙 - 상기 형상 피쳐 규칙은 상기 면적 규칙을 포함함 - 을 만족한다고 결정
하도록 추가로 구성된, 시스템.
The apparatus of claim 1, wherein the finder module comprises:
Calculating an area value of the candidate shape feature from the image data, the area value calculated in conjunction with another candidate shape feature to scale the area value;
Determine an area score for the candidate shape feature by comparing the area value with a reference area value of the custom graphics;
Based on the area score exceeding the threshold, determines that the candidate shape feature satisfies an area rule - the shape feature rule includes the area rule
Further comprising:
컴퓨터 구현된 방법으로서,
맞춤형 심볼에 대한 기준 이미지의 기준 이미지 데이터를 수신하는 단계;
상기 기준 이미지 데이터로부터 상기 기준 이미지의 기준 형상 피쳐를 결정하는 단계 - 상기 기준 형상 피쳐는 상기 맞춤형 심볼의 정체성을 나타냄 -;
사용자 디바이스로부터 이미지의 이미지 데이터를 수신하는 단계;
상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하는 단계;
상기 후보 형상 피쳐가 형상 피쳐 기준을 만족한다는 것을 결정하는 단계;
상기 후보 형상 피쳐가 상기 형상 피쳐 기준을 만족하는 것에 응답하여, 상기 후보 형상 피쳐를 상기 맞춤형 심볼의 상기 기준 형상 피쳐와 비교함으로써 상기 이미지에서 상기 맞춤형 심볼을 식별하는 단계;
상기 맞춤형 심볼을 식별하는 것에 응답하여, 상기 이미지 데이터로부터 상기 이미지 내의 상기 맞춤형 심볼의 기하학적 속성을 추출하는 단계; 및
상기 이미지 내의 상기 맞춤형 심볼의 상기 기하학적 속성을 이용하여 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하는 단계
를 포함하는 방법.
As a computer implemented method,
Receiving reference image data of a reference image for a custom symbol;
Determining a reference shape feature of the reference image from the reference image data, the reference shape feature representing an identity of the customized symbol;
Receiving image data of an image from a user device;
Extracting a candidate shape feature of the image from the image data;
Determining that the candidate shape feature satisfies a shape feature criterion;
Identifying the customizable symbol in the image by comparing the candidate shape feature with the reference shape feature of the customizable symbol in response to the candidate shape feature satisfying the feature feature criteria;
Extracting a geometric attribute of the customizable symbol in the image from the image data in response to identifying the customizable symbol; And
Decoding the data encoded within a portion of the image from the image data using the geometric property of the custom symbol in the image
≪ / RTI >
제3항에 있어서,
상기 이미지 데이터로부터 상기 후보 형상 피쳐의 크기 근사를 계산하는 단계 - 상기 크기 근사는 상기 크기 근사를 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨 -;
상기 크기 근사를 상기 맞춤형 심볼의 기준 크기와 비교함으로써 상기 후보 형상 피쳐에 대한 크기 점수를 결정하는 단계; 및
임계값을 초과하는 상기 크기 점수에 기초하여 상기 후보 형상 피쳐가 크기 기준을 만족한다는 것을 결정하는 단계 - 상기 형상 피쳐 기준은 상기 크기 기준을 포함함 -
를 추가로 포함하는 방법.
The method of claim 3,
Calculating a magnitude approximation of the candidate shape feature from the image data, wherein the magnitude approximation is computed in conjunction with another candidate shape feature to scale the magnitude approximation;
Determining a size score for the candidate shape feature by comparing the size approximation with a reference size of the custom symbol; And
Determining that the candidate shape feature satisfies a size criterion based on the size score exceeding a threshold, the shape feature criterion including the size criterion,
≪ / RTI >
제3항에 있어서,
상기 이미지 데이터로부터 상기 후보 형상 피쳐가 폐곡선을 포함한다는 것을 결정하는 단계 - 상기 폐곡선은 특정한 지점에서 시작하여 상기 특정한 지점으로 복귀하는 경로를 가짐으로써 상기 이미지의 일부를 둘러쌈 -; 및
상기 폐곡선을 포함하는 상기 후보 형상 피쳐에 기초하여 상기 후보 형상 피쳐가 경로 기준을 만족한다는 것을 결정하는 단계 - 상기 형상 피쳐 기준은 상기 경로 기준을 포함함 -
를 추가로 포함하는 방법.
The method of claim 3,
Determining from the image data that the candidate shape feature comprises a closed curve, the closed curve having a path starting at a particular point and returning to the particular point, surrounding the portion of the image; And
Determining that the candidate shape feature satisfies a path criterion based on the candidate feature comprising the closed curve, the shape feature criterion comprising the path criterion,
≪ / RTI >
제3항에 있어서, 상기 기하학적 속성은 상기 이미지 내의 상기 맞춤형 심볼의 위치, 스케일, 또는 배향 중 적어도 하나를 포함하는, 방법.4. The method of claim 3, wherein the geometric attribute comprises at least one of position, scale, or orientation of the customized symbol in the image. 제3항에 있어서,
상기 이미지 데이터로부터 상기 맞춤형 심볼의 고유 피쳐를 추출하는 단계 - 상기 고유 피쳐는 상기 맞춤형 심볼의 식별을 나타냄 -;
상기 고유 피쳐를 상기 맞춤형 심볼의 기준 고유 피쳐와 비교함으로써 상기 이미지 내의 상기 맞춤형 심볼의 배향을 결정하는 단계; 및
상기 이미지 내의 상기 맞춤형 심볼의 상기 배향 및 위치를 이용하여 상기 이미지 내에 인코딩된 데이터를 디코딩하는 단계
를 추가로 포함하는 방법.
The method of claim 3,
Extracting a unique feature of the custom symbol from the image data, the unique feature indicating identification of the custom symbol;
Determining an orientation of the custom symbol in the image by comparing the intrinsic feature with a reference intrinsic feature of the custom symbol; And
Decoding the encoded data in the image using the orientation and position of the customized symbol in the image
≪ / RTI >
제7항에 있어서,
상기 이미지 내의 상기 맞춤형 심볼의 고유 지점을 식별하는 단계 - 상기 고유 피쳐는 상기 고유 지점을 포함함 -; 및
상기 이미지 내의 상기 맞춤형 심볼에 관한 상기 고유 지점의 위치를 상기 맞춤형 심볼의 기준 지점의 위치와 비교함으로써 상기 이미지 내의 상기 맞춤형 심볼의 배향을 결정하는 단계
를 추가로 포함하는 방법.
8. The method of claim 7,
Identifying an intrinsic point of the custom symbol in the image, the intrinsic feature comprising the intrinsic point; And
Determining an orientation of the custom symbol in the image by comparing a position of the unique point with respect to the custom symbol in the image to a position of a reference point of the custom symbol
≪ / RTI >
제7항에 있어서,
상기 맞춤형 심볼의 배향에 따라 상기 이미지를 변환함으로써 변환된 이미지를 생성하는 단계; 및
상기 변환된 이미지를 이용하여 상기 이미지의 상기 일부 내에 인코딩된 데이터를 디코딩하는 단계
를 추가로 포함하는 방법.
8. The method of claim 7,
Generating a transformed image by transforming the image according to the orientation of the customized symbol; And
Decoding the encoded data within the portion of the image using the transformed image
≪ / RTI >
제9항에 있어서,
상기 변환된 이미지를 이용한, 상기 이미지의 상기 일부 내에 인코딩된 데이터의 디코딩 실패를 결정하는 단계;
상기 맞춤형 심볼의 상이한 배향에 따라 상기 이미지를 변환함으로써 또 다른 변환된 이미지를 생성하는 단계; 및
상기 또 다른 변환된 이미지를 이용하여 상기 이미지의 상기 일부 내에 인코딩된 데이터를 디코딩하는 단계
를 추가로 포함하는 방법.
10. The method of claim 9,
Determining a decoding failure of the encoded data in the portion of the image using the transformed image;
Generating another transformed image by transforming the image according to a different orientation of the customized symbol; And
Decoding the encoded data within the portion of the image using the another transformed image
≪ / RTI >
제3항에 있어서, 상기 이미지의 상기 일부 내에 인코딩된 데이터는 상기 이미지 내의 상기 맞춤형 심볼에 관해 위치한 복수의 마크들을 이용하여 인코딩되고, 상기 복수의 마크들의 각각의 마크는 데이터 조각을 나타내는, 방법.4. The method of claim 3, wherein the data encoded within the portion of the image is encoded using a plurality of marks located relative to the customizable symbol in the image, wherein each mark of the plurality of marks represents a piece of data. 제3항에 있어서, 상기 맞춤형 심볼은, 로고, 아이콘, 또는 상표 중 적어도 하나를 포함하는, 방법.4. The method of claim 3, wherein the customizable symbol comprises at least one of a logo, an icon, or a trademark. 제3항에 있어서,
상기 사용자 디바이스의 이미지 센서로부터 상기 이미지 데이터를 실시간으로 수신하는 단계를 추가로 포함하는 방법.
The method of claim 3,
Further comprising receiving the image data in real time from an image sensor of the user device.
제3항에 있어서, 상기 맞춤형 심볼의 형상은 적어도 하나의 비대칭성을 포함하는, 방법.4. The method of claim 3, wherein the shape of the custom symbol comprises at least one asymmetry. 제3항에 있어서,
상기 이미지 내에 인코딩된 데이터를 디코딩하는 것에 응답하여, 상기 이미지로부터 디코딩된 데이터를 이용하여 상기 사용자 디바이스 관해 동작을 수행하는 단계를 추가로 포함하는 방법.
The method of claim 3,
Further comprising performing, in response to decoding the encoded data in the image, operation with respect to the user device using decoded data from the image.
제15항에 있어서, 상기 동작은 상기 이미지로부터 디코딩된 데이터에 의해 명시된 동작을 포함하는, 방법.16. The method of claim 15, wherein the operation includes an operation specified by decoded data from the image. 제15항에 있어서, 상기 동작은 서버와의 통신없이 수행되는, 방법.16. The method of claim 15, wherein the operation is performed without communication with a server. 제15항에 있어서, 상기 동작은 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩한 모바일 컴퓨팅 애플리케이션에 전용되는, 방법.16. The method of claim 15, wherein the operation is dedicated to a mobile computing application that decoded data encoded within a portion of the image. 머신의 적어도 하나의 프로세서에 의해 실행될 때, 상기 머신으로 하여금 동작들을 수행하게 하는 명령어들을 포함하는 머신-판독가능한 매체로서, 상기 동작들은,
특정한 디자인에 대한 기준 이미지의 기준 이미지 데이터를 수신하는 단계;
상기 기준 이미지 데이터로부터 상기 기준 이미지의 기준 형상 피쳐를 결정하는 단계 - 상기 기준 형상 피쳐는 상기 특정한 디자인의 정체성을 나타냄 -;
클라이언트 시스템으로부터 이미지의 이미지 데이터를 수신하는 단계;
상기 이미지 데이터로부터 상기 이미지의 후보 형상 피쳐를 추출하는 단계;
상기 후보 형상 피쳐가 형상 피쳐 규칙을 만족한다는 것을 결정하는 단계;
상기 후보 형상 피쳐가 상기 형상 피쳐 규칙을 만족하는 것에 응답하여, 상기 후보 형상 피쳐를 상기 특정한 디자인의 상기 기준 형상 피쳐와 비교함으로써 상기 이미지에서 상기 특정한 디자인을 식별하는 단계;
상기 특정한 디자인을 식별하는 것에 응답하여, 상기 이미지 데이터로부터 상기 이미지 내의 상기 특정한 디자인의 공간적 속성을 추출하는 단계; 및
상기 이미지 내의 상기 특정한 디자인의 상기 공간적 속성을 이용하여 상기 이미지 데이터로부터 상기 이미지의 일부 내에 인코딩된 데이터를 디코딩하는 단계
를 포함하는, 머신-판독가능한 매체.
A machine-readable medium comprising instructions that, when executed by at least one processor of a machine, cause the machine to perform operations,
Receiving reference image data of a reference image for a particular design;
Determining a reference shape feature of the reference image from the reference image data, the reference shape feature representing an identity of the particular design;
Receiving image data of an image from a client system;
Extracting a candidate shape feature of the image from the image data;
Determining that the candidate shape feature satisfies a shape feature rule;
Identifying the particular design in the image by comparing the candidate shape feature with the reference shape feature of the particular design in response to the candidate shape feature satisfying the shape feature rule;
Extracting a spatial attribute of the particular design within the image from the image data in response to identifying the particular design; And
Decoding the data encoded within a portion of the image from the image data using the spatial property of the particular design within the image
Readable medium.
제19항에 있어서, 상기 동작들은,
상기 이미지 데이터로부터 상기 후보 형상 피쳐의 크기 근사를 계산하는 단계 - 상기 크기 근사는 상기 크기 근사를 스케일링하기 위해 또 다른 후보 형상 피쳐와 연계하여 계산됨 -;
상기 크기 근사를 상기 특정한 디자인의 기준 크기와 비교함으로써 상기 후보 형상 피쳐에 대한 크기 점수를 결정하는 단계; 및
임계값을 초과하는 상기 크기 점수에 기초하여 상기 후보 형상 피쳐가 크기 규칙을 만족한다는 것을 결정하는 단계 - 상기 형상 피쳐 규칙은 상기 크기 규칙을 포함함 -
를 추가로 포함하는 머신-판독가능한 매체.
20. The method of claim 19,
Calculating a magnitude approximation of the candidate shape feature from the image data, wherein the magnitude approximation is computed in conjunction with another candidate shape feature to scale the magnitude approximation;
Determining a size score for the candidate shape feature by comparing the size approximation to a reference size of the particular design; And
Determining that the candidate shape feature satisfies a size rule based on the size score exceeding a threshold value, the shape feature rule including the size rule,
Readable < / RTI > media.
컴퓨터의 적어도 하나의 프로세서에 의해 실행될 때, 상기 컴퓨터로 하여금, 제3항 내지 제18항 중 어느 한 항의 방법을 실행하게 하는 명령어들을 포함하는 머신-판독가능한 매체.19. A machine-readable medium comprising instructions that when executed by at least one processor of a computer cause the computer to perform the method of any of claims 3-18.
KR1020177023059A 2015-01-19 2016-01-08 Custom Function Patterns for Optical Barcodes KR102018143B1 (en)

Applications Claiming Priority (7)

Application Number Priority Date Filing Date Title
US201562105141P 2015-01-19 2015-01-19
US62/105,141 2015-01-19
US14/612,409 2015-02-03
US14/612,409 US9111164B1 (en) 2015-01-19 2015-02-03 Custom functional patterns for optical barcodes
US14/826,301 US9659244B2 (en) 2015-01-19 2015-08-14 Custom functional patterns for optical barcodes
US14/826,301 2015-08-14
PCT/US2016/012669 WO2016118338A1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes

Related Child Applications (1)

Application Number Title Priority Date Filing Date
KR1020197025362A Division KR102144391B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes

Publications (2)

Publication Number Publication Date
KR20170128239A true KR20170128239A (en) 2017-11-22
KR102018143B1 KR102018143B1 (en) 2019-11-04

Family

ID=53786051

Family Applications (5)

Application Number Title Priority Date Filing Date
KR1020217015611A KR102416030B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes
KR1020207022897A KR102257908B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes
KR1020227022159A KR102514483B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes
KR1020177023059A KR102018143B1 (en) 2015-01-19 2016-01-08 Custom Function Patterns for Optical Barcodes
KR1020197025362A KR102144391B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes

Family Applications Before (3)

Application Number Title Priority Date Filing Date
KR1020217015611A KR102416030B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes
KR1020207022897A KR102257908B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes
KR1020227022159A KR102514483B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes

Family Applications After (1)

Application Number Title Priority Date Filing Date
KR1020197025362A KR102144391B1 (en) 2015-01-19 2016-01-08 Custom functional patterns for optical barcodes

Country Status (5)

Country Link
US (6) US9111164B1 (en)
EP (2) EP3248145A4 (en)
KR (5) KR102416030B1 (en)
CN (2) CN112183536A (en)
WO (1) WO2016118338A1 (en)

Families Citing this family (129)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2013166588A1 (en) 2012-05-08 2013-11-14 Bitstrips Inc. System and method for adaptable avatars
US9705831B2 (en) 2013-05-30 2017-07-11 Snap Inc. Apparatus and method for maintaining a message thread with opt-in permanence for entries
US10439972B1 (en) 2013-05-30 2019-10-08 Snap Inc. Apparatus and method for maintaining a message thread with opt-in permanence for entries
US9594555B2 (en) 2014-04-07 2017-03-14 Quikkly Ltd. Computer readable storage media for invoking direct actions and processes and systems utilizing same
US9276886B1 (en) 2014-05-09 2016-03-01 Snapchat, Inc. Apparatus and method for dynamically configuring application component tiles
US9396354B1 (en) 2014-05-28 2016-07-19 Snapchat, Inc. Apparatus and method for automated privacy protection in distributed images
US9537811B2 (en) 2014-10-02 2017-01-03 Snap Inc. Ephemeral gallery of ephemeral messages
US9113301B1 (en) 2014-06-13 2015-08-18 Snapchat, Inc. Geo-location based event gallery
US10824654B2 (en) 2014-09-18 2020-11-03 Snap Inc. Geolocation-based pictographs
US10284508B1 (en) 2014-10-02 2019-05-07 Snap Inc. Ephemeral gallery of ephemeral messages with opt-in permanence
JP6520616B2 (en) * 2014-10-07 2019-05-29 株式会社デンソーウェーブ Information code generation method, program for generating information code, and information code generation apparatus
US10311916B2 (en) 2014-12-19 2019-06-04 Snap Inc. Gallery of videos set to an audio time line
US9385983B1 (en) 2014-12-19 2016-07-05 Snapchat, Inc. Gallery of messages from individuals with a shared interest
US9754355B2 (en) 2015-01-09 2017-09-05 Snap Inc. Object recognition based photo filters
US9111164B1 (en) 2015-01-19 2015-08-18 Snapchat, Inc. Custom functional patterns for optical barcodes
US10133705B1 (en) 2015-01-19 2018-11-20 Snap Inc. Multichannel system
US9294425B1 (en) 2015-02-06 2016-03-22 Snapchat, Inc. Storage and processing of ephemeral messages
US11582202B2 (en) * 2015-02-16 2023-02-14 Arebus, LLC System, method and application for transcoding data into media files
EP3272078B1 (en) 2015-03-18 2022-01-19 Snap Inc. Geo-fence authorization provisioning
US10691314B1 (en) * 2015-05-05 2020-06-23 State Farm Mutual Automobile Insurance Company Connecting users to entities based on recognized objects
US10135949B1 (en) 2015-05-05 2018-11-20 Snap Inc. Systems and methods for story and sub-story navigation
US11088987B2 (en) 2015-05-06 2021-08-10 Snap Inc. Ephemeral group chat
US10503264B1 (en) 2015-06-16 2019-12-10 Snap Inc. Radial gesture navigation
US9906479B1 (en) 2015-06-16 2018-02-27 Snap Inc. Storage management for ephemeral messages
US11121997B1 (en) 2015-08-24 2021-09-14 Snap Inc. Systems, devices, and methods for determining a non-ephemeral message status in a communication system
US10616162B1 (en) 2015-08-24 2020-04-07 Snap Inc. Systems devices and methods for automatically selecting an ephemeral message availability
US10157333B1 (en) 2015-09-15 2018-12-18 Snap Inc. Systems and methods for content tagging
US9721551B2 (en) 2015-09-29 2017-08-01 Amper Music, Inc. Machines, systems, processes for automated music composition and generation employing linguistic and/or graphical icon based musical experience descriptions
US10854180B2 (en) 2015-09-29 2020-12-01 Amper Music, Inc. Method of and system for controlling the qualities of musical energy embodied in and expressed by digital music to be automatically composed and generated by an automated music composition and generation engine
US9652896B1 (en) 2015-10-30 2017-05-16 Snap Inc. Image based tracking in augmented reality systems
US10338753B2 (en) 2015-11-03 2019-07-02 Microsoft Technology Licensing, Llc Flexible multi-layer sensing surface
US10955977B2 (en) 2015-11-03 2021-03-23 Microsoft Technology Licensing, Llc Extender object for multi-modal sensing
US10649572B2 (en) 2015-11-03 2020-05-12 Microsoft Technology Licensing, Llc Multi-modal sensing surface
US11119628B1 (en) 2015-11-25 2021-09-14 Snap Inc. Dynamic graphical user interface modification and monitoring
US9984499B1 (en) 2015-11-30 2018-05-29 Snap Inc. Image and point cloud based tracking and in augmented reality systems
US10354425B2 (en) 2015-12-18 2019-07-16 Snap Inc. Method and system for providing context relevant media augmentation
WO2017132634A1 (en) * 2016-01-28 2017-08-03 Ptc Inc. User-designed machine-readable target codes
CA3052241A1 (en) 2016-02-05 2017-08-10 Fredrick T. Howard Time limited image sharing
US9911073B1 (en) 2016-03-18 2018-03-06 Snap Inc. Facial patterns for optical barcodes
US10530731B1 (en) 2016-03-28 2020-01-07 Snap Inc. Systems and methods for chat with audio and video elements
US10270839B2 (en) 2016-03-29 2019-04-23 Snap Inc. Content collection navigation and autoforwarding
US10339365B2 (en) 2016-03-31 2019-07-02 Snap Inc. Automated avatar generation
US10686899B2 (en) 2016-04-06 2020-06-16 Snap Inc. Messaging achievement pictograph display system
US9813642B1 (en) 2016-05-06 2017-11-07 Snap Inc. Dynamic activity-based image generation
US10474353B2 (en) 2016-05-31 2019-11-12 Snap Inc. Application control using a gesture based trigger
US11507977B2 (en) 2016-06-28 2022-11-22 Snap Inc. Methods and systems for presentation of media collections with automated advertising
US9681265B1 (en) 2016-06-28 2017-06-13 Snap Inc. System to track engagement of media items
US10182047B1 (en) 2016-06-30 2019-01-15 Snap Inc. Pictograph password security system
US11334768B1 (en) 2016-07-05 2022-05-17 Snap Inc. Ephemeral content management
US10552968B1 (en) 2016-09-23 2020-02-04 Snap Inc. Dense feature scale detection for image matching
CN109791621B (en) * 2016-09-26 2022-09-30 斯纳普公司 Device pairing using optical codes
US10609036B1 (en) 2016-10-10 2020-03-31 Snap Inc. Social media post subscribe requests for buffer user accounts
US10198626B2 (en) * 2016-10-19 2019-02-05 Snap Inc. Neural networks for facial modeling
US10432559B2 (en) 2016-10-24 2019-10-01 Snap Inc. Generating and displaying customized avatars in electronic messages
CN113206959B (en) 2016-11-01 2024-01-09 斯纳普公司 Method and server for determining automatic enclosure configuration
US10733489B2 (en) * 2016-11-17 2020-08-04 Nanyang Technological University Optically readable tags and methods and systems for decoding an optically readable tag
US10740939B1 (en) 2016-12-09 2020-08-11 Snap Inc. Fast image style transfers
US10242477B1 (en) * 2017-01-16 2019-03-26 Snap Inc. Coded vision system
US11630877B1 (en) * 2017-01-24 2023-04-18 Snap Inc. Custom visual codes for network links
US10319149B1 (en) 2017-02-17 2019-06-11 Snap Inc. Augmented reality anamorphosis system
US10374993B2 (en) 2017-02-20 2019-08-06 Snap Inc. Media item attachment system
US11019001B1 (en) 2017-02-20 2021-05-25 Snap Inc. Selective presentation of group messages
US10074381B1 (en) 2017-02-20 2018-09-11 Snap Inc. Augmented reality speech balloon system
US10878837B1 (en) 2017-03-01 2020-12-29 Snap Inc. Acoustic neural network scene detection
US10146971B1 (en) 2017-03-14 2018-12-04 Snap Inc. Optical barcodes without orientation
US10582277B2 (en) 2017-03-27 2020-03-03 Snap Inc. Generating a stitched data stream
US10581782B2 (en) 2017-03-27 2020-03-03 Snap Inc. Generating a stitched data stream
US11170393B1 (en) 2017-04-11 2021-11-09 Snap Inc. System to calculate an engagement score of location based media content
US10387730B1 (en) 2017-04-20 2019-08-20 Snap Inc. Augmented reality typography personalization system
US10382372B1 (en) 2017-04-27 2019-08-13 Snap Inc. Processing media content based on original context
CN110800018A (en) 2017-04-27 2020-02-14 斯纳普公司 Friend location sharing mechanism for social media platform
US11893647B2 (en) 2017-04-27 2024-02-06 Snap Inc. Location-based virtual avatars
US10212541B1 (en) 2017-04-27 2019-02-19 Snap Inc. Selective location-based identity communication
US10943255B1 (en) 2017-04-28 2021-03-09 Snap Inc. Methods and systems for interactive advertising with media collections
WO2018208293A1 (en) * 2017-05-09 2018-11-15 Visa International Service Association Video matrix barcode system
US10679428B1 (en) 2017-05-26 2020-06-09 Snap Inc. Neural network-based image stream modification
US10788900B1 (en) 2017-06-29 2020-09-29 Snap Inc. Pictorial symbol prediction
CN111033527A (en) 2017-07-28 2020-04-17 可口可乐公司 Method and apparatus for encoding and decoding circular symbol code
US11216517B1 (en) 2017-07-31 2022-01-04 Snap Inc. Methods and systems for selecting user generated content
US11323398B1 (en) 2017-07-31 2022-05-03 Snap Inc. Systems, devices, and methods for progressive attachments
US11164376B1 (en) 2017-08-30 2021-11-02 Snap Inc. Object modeling using light projection
US9980100B1 (en) 2017-08-31 2018-05-22 Snap Inc. Device location based on machine learning classifications
US10740974B1 (en) 2017-09-15 2020-08-11 Snap Inc. Augmented reality system
US10474900B2 (en) 2017-09-15 2019-11-12 Snap Inc. Real-time tracking-compensated image effects
US10891723B1 (en) 2017-09-29 2021-01-12 Snap Inc. Realistic neural network based image style transfer
US10872292B1 (en) 2017-10-09 2020-12-22 Snap Inc. Compact neural networks using condensed filters
US10810277B1 (en) 2017-10-30 2020-10-20 Facebook, Inc. System and method for determination of a digital destination based on a multi-part identifier
US10650072B2 (en) 2017-10-30 2020-05-12 Facebook, Inc. System and method for determination of a digital destination based on a multi-part identifier
US10599289B1 (en) 2017-11-13 2020-03-24 Snap Inc. Interface to display animated icon
US11551059B1 (en) 2017-11-15 2023-01-10 Snap Inc. Modulated image segmentation
US10885564B1 (en) * 2017-11-28 2021-01-05 Snap Inc. Methods, system, and non-transitory computer readable storage medium for dynamically configurable social media platform
US10217488B1 (en) 2017-12-15 2019-02-26 Snap Inc. Spherical video editing
US11017173B1 (en) 2017-12-22 2021-05-25 Snap Inc. Named entity recognition visual context and caption data
CN109960957B (en) 2017-12-26 2022-12-16 阿里巴巴集团控股有限公司 Incomplete two-dimensional code and generation, repair and identification methods, devices and systems thereof
US10523606B2 (en) 2018-01-02 2019-12-31 Snap Inc. Generating interactive messages with asynchronous media content
US10482565B1 (en) 2018-02-12 2019-11-19 Snap Inc. Multistage neural network processing using a graphics processor
US10726603B1 (en) 2018-02-28 2020-07-28 Snap Inc. Animated expressive icon
US10885136B1 (en) 2018-02-28 2021-01-05 Snap Inc. Audience filtering system
US10327096B1 (en) 2018-03-06 2019-06-18 Snap Inc. Geo-fence selection system
CN108573184B (en) * 2018-03-12 2021-04-27 青岛乾程科技股份有限公司 Two-dimensional code positioning method, module and computer readable storage medium
US11310176B2 (en) 2018-04-13 2022-04-19 Snap Inc. Content suggestion system
EP3782124A1 (en) 2018-04-18 2021-02-24 Snap Inc. Augmented expression system
CN110414646B (en) * 2018-04-28 2023-05-30 深圳果力智能科技有限公司 Robot control pattern generation method
US11487501B2 (en) 2018-05-16 2022-11-01 Snap Inc. Device control using audio data
US10997760B2 (en) 2018-08-31 2021-05-04 Snap Inc. Augmented reality anthropomorphization system
US11297027B1 (en) 2019-01-31 2022-04-05 Snap Inc. Automated image processing and insight presentation
US11972529B2 (en) 2019-02-01 2024-04-30 Snap Inc. Augmented reality system
US10650210B1 (en) * 2019-03-18 2020-05-12 Haier Us Appliance Solutions, Inc. Method for authenticating a filter cartridge for a refrigerator appliance
US11134036B2 (en) 2019-07-05 2021-09-28 Snap Inc. Event planning in a content sharing platform
US11812347B2 (en) 2019-09-06 2023-11-07 Snap Inc. Non-textual communication and user states management
US10964299B1 (en) 2019-10-15 2021-03-30 Shutterstock, Inc. Method of and system for automatically generating digital performances of music compositions using notes selected from virtual musical instruments based on the music-theoretic states of the music compositions
US11037538B2 (en) 2019-10-15 2021-06-15 Shutterstock, Inc. Method of and system for automated musical arrangement and musical instrument performance style transformation supported within an automated music performance system
US11024275B2 (en) 2019-10-15 2021-06-01 Shutterstock, Inc. Method of digitally performing a music composition using virtual musical instruments having performance logic executing within a virtual musical instrument (VMI) library management system
US11316806B1 (en) 2020-01-28 2022-04-26 Snap Inc. Bulk message deletion
US11265281B1 (en) 2020-01-28 2022-03-01 Snap Inc. Message deletion policy selection
US11625873B2 (en) 2020-03-30 2023-04-11 Snap Inc. Personalized media overlay recommendation
KR20220157502A (en) * 2020-03-31 2022-11-29 스냅 인코포레이티드 Augmented Reality Beauty Product Tutorials
US11700225B2 (en) 2020-04-23 2023-07-11 Snap Inc. Event overlay invite messaging system
US11194981B2 (en) * 2020-05-11 2021-12-07 Flexa Network Inc. Multi-part code system
US11843574B2 (en) 2020-05-21 2023-12-12 Snap Inc. Featured content collection interface
US11543939B2 (en) * 2020-06-08 2023-01-03 Snap Inc. Encoded image based messaging system
KR20230022241A (en) 2020-06-10 2023-02-14 스냅 인코포레이티드 Visual search to launch applications
US11423652B2 (en) 2020-06-10 2022-08-23 Snap Inc. Adding beauty products to augmented reality tutorials
US11899905B2 (en) 2020-06-30 2024-02-13 Snap Inc. Selectable items providing post-viewing context actions
WO2022010455A1 (en) * 2020-07-06 2022-01-13 Hewlett-Packard Development Company, L.P. Data decode
US11625916B2 (en) * 2020-07-31 2023-04-11 Zebra Technologies Corporation Automatic identification and presentation of edges, shapes and unique objects in an image used for a machine vision job setup
US11832015B2 (en) 2020-08-13 2023-11-28 Snap Inc. User interface for pose driven virtual effects
US11973730B2 (en) 2022-06-02 2024-04-30 Snap Inc. External messaging function for an interaction system
US11983390B2 (en) * 2022-08-18 2024-05-14 Snap Inc. Interacting with visual codes within messaging system

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6327388B1 (en) * 1998-08-14 2001-12-04 Matsushita Electric Industrial Co., Ltd. Identification of logos from document images
US7410099B2 (en) * 2003-06-05 2008-08-12 Ntt Docomo, Inc. Apparatus and method for reading and decoding information contained in a barcode
US7412089B2 (en) * 2005-05-23 2008-08-12 Nextcode Corporation Efficient finder patterns and methods for application to 2D machine vision problems
US8868902B1 (en) * 2013-07-01 2014-10-21 Cryptite LLC Characteristically shaped colorgram tokens in mobile transactions

Family Cites Families (60)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5591956A (en) * 1995-05-15 1997-01-07 Welch Allyn, Inc. Two dimensional data encoding structure and symbology for use with optical readers
US5978773A (en) 1995-06-20 1999-11-02 Neomedia Technologies, Inc. System and method for using an ordinary article of commerce to access a remote computer
EP0814611B1 (en) 1996-06-17 2002-08-28 Siemens Aktiengesellschaft Communication system and method for recording and managing digital images
US7173651B1 (en) 1998-06-02 2007-02-06 Knowles Andrew T Apparatus and system for prompt digital photo delivery and archival
US6204854B1 (en) 1998-12-04 2001-03-20 France Telecom Method and system for encoding rotations and normals in 3D generated scenes
US6565003B1 (en) * 1998-12-16 2003-05-20 Matsushita Electric Industrial Co., Ltd. Method for locating and reading a two-dimensional barcode
US6523826B1 (en) 1999-07-12 2003-02-25 Jose R. Matos Folding picture puzzle with decoding lenses and encoded images
US6505123B1 (en) 2000-07-24 2003-01-07 Weatherbank, Inc. Interactive weather advisory system
US20100098702A1 (en) 2008-09-16 2010-04-22 Longgui Wang Method of treating androgen independent prostate cancer
JP2004209726A (en) 2002-12-27 2004-07-29 Brother Ind Ltd Image data generator and program
US7411493B2 (en) 2003-03-01 2008-08-12 User-Centric Ip, L.P. User-centric event reporting
US7535890B2 (en) 2003-12-18 2009-05-19 Ayalogic, Inc. System and method for instant VoIP messaging
KR100560330B1 (en) * 2004-04-21 2006-03-30 에이디정보통신 주식회사 A bar code perfect virtue coding and decoding system for largeness a volume the two dimension color which a color revision is possible and method thereof
KR100701292B1 (en) * 2004-08-17 2007-03-29 (주)아이미디어아이앤씨 Image code and method and apparatus for recognizing thereof
KR100653886B1 (en) * 2004-11-05 2006-12-05 주식회사 칼라짚미디어 Mixed-code and mixed-code encondig method and apparatus
WO2007023494A2 (en) 2005-08-22 2007-03-01 Triplay Communications Ltd. Messaging system and method
WO2007075719A2 (en) 2005-12-16 2007-07-05 Pisafe, Inc. Method and system for creating and using barcodes
US8094870B2 (en) 2006-01-27 2012-01-10 Spyder Lynk, Llc Encoding and decoding data in an image
US20080048044A1 (en) 2006-08-25 2008-02-28 Microsoft Corporation Barcode Encoding and Decoding
US8194914B1 (en) 2006-10-19 2012-06-05 Spyder Lynk, Llc Encoding and decoding data into an image using identifiable marks and encoded elements
USRE47534E1 (en) 2007-04-23 2019-07-23 Ramot At Tel Aviv University Ltd. System, method and a computer readable medium for providing an output image
US7886978B2 (en) * 2007-09-20 2011-02-15 Microsoft Corporation Techniques for decoding images of barcodes
AP2996A (en) * 2008-04-02 2014-10-31 Sicpa Holding Sa Identification and authentication using liquid crystal material markings
US9491184B2 (en) 2008-04-04 2016-11-08 Samsung Electronics Co., Ltd. Method and apparatus for managing tokens for digital rights management
EP2373002A4 (en) 2008-12-26 2012-07-25 Panasonic Corp Image capture device
WO2011101784A1 (en) 2010-02-16 2011-08-25 Tigertext Inc. A messaging system apparatuses circuits and methods of operation thereof
JP4874436B2 (en) 2010-03-26 2012-02-15 A・Tコミュニケーションズ株式会社 Two-dimensional code with logo, two-dimensional code generation device with logo, two-dimensional code generation method with logo, and program
US9213920B2 (en) * 2010-05-28 2015-12-15 Zazzle.Com, Inc. Using infrared imaging to create digital images for use in product customization
US8272562B2 (en) * 2010-10-11 2012-09-25 Andrew Ziegler Promotional hang tag, tag, or label combined with promotional product sample, with interactive quick response (QR code, MS tag) or other scan-able interactive code linked to one or more internet uniform resource locators (URLs) for instantly delivering wide band digital content, promotions and infotainment brand engagement features between consumers and marketers
JP5773323B2 (en) 2011-08-09 2015-09-02 インテル・コーポレーション Multi-view 3D face generation based on images
KR101860569B1 (en) * 2011-09-08 2018-07-03 삼성전자주식회사 Recognition device for text and barcode reconizing text and barcode simultaneously
US8931700B2 (en) * 2011-12-23 2015-01-13 Konica Minolta Laboratory U.S.A., Inc. Four dimensional (4D) color barcode for high capacity data encoding and decoding
GB201122284D0 (en) 2011-12-23 2012-02-01 Zappar Ltd Content identification and distribution
KR20140141594A (en) * 2012-02-21 2014-12-10 아이코닛 리미티드 Readable matrix code
CN102622628B (en) * 2012-02-24 2014-09-03 南京大学 Method for generating quick response (QR) codes in rendering mode
US8515139B1 (en) 2012-03-15 2013-08-20 Google Inc. Facial feature detection
US9177130B2 (en) 2012-03-15 2015-11-03 Google Inc. Facial feature detection
US9317113B1 (en) 2012-05-31 2016-04-19 Amazon Technologies, Inc. Gaze assisted object recognition
US8441548B1 (en) 2012-06-15 2013-05-14 Google Inc. Facial image quality assessment
KR101442229B1 (en) * 2012-06-15 2014-09-25 주식회사 나인플라바 System for marketing and sharing information based on SNS
US8396265B1 (en) 2012-06-26 2013-03-12 Google Inc. Facial recognition
US8457367B1 (en) 2012-06-26 2013-06-04 Google Inc. Facial recognition
US8411909B1 (en) 2012-06-26 2013-04-02 Google Inc. Facial recognition
US8886953B1 (en) 2012-09-14 2014-11-11 Google Inc. Image processing
JP6136808B2 (en) * 2012-12-19 2017-05-31 株式会社デンソーウェーブ Information code generation method, information code, information code reader, and information code utilization system
KR20140103021A (en) * 2013-02-15 2014-08-25 삼성전자주식회사 Object recognition device
US20140263674A1 (en) * 2013-03-15 2014-09-18 Conformis, Inc. Systems, Methods, and Apparatus for Integrating Scannable Codes in Medical Devices
DE112014001662T5 (en) * 2013-03-27 2015-12-17 Denso Wave Incorporated Apparatus and method for generating a two-dimensional code contained in an image
US9147095B2 (en) 2013-11-22 2015-09-29 Ncr Corporation Optical code scanner optimized for reading 2D optical codes
WO2015077455A1 (en) 2013-11-25 2015-05-28 Digimarc Corporation Methods and systems for contextually processing imagery
CA2863124A1 (en) 2014-01-03 2015-07-03 Investel Capital Corporation User content sharing system and method with automated external content integration
US9594555B2 (en) 2014-04-07 2017-03-14 Quikkly Ltd. Computer readable storage media for invoking direct actions and processes and systems utilizing same
US9740841B2 (en) 2014-09-08 2017-08-22 Tessera Advanced Technologies, Inc. Using biometric user-specific attributes
JP6520616B2 (en) * 2014-10-07 2019-05-29 株式会社デンソーウェーブ Information code generation method, program for generating information code, and information code generation apparatus
US9111164B1 (en) 2015-01-19 2015-08-18 Snapchat, Inc. Custom functional patterns for optical barcodes
JP6754619B2 (en) 2015-06-24 2020-09-16 三星電子株式会社Samsung Electronics Co.,Ltd. Face recognition method and device
US9911073B1 (en) 2016-03-18 2018-03-06 Snap Inc. Facial patterns for optical barcodes
US10146971B1 (en) 2017-03-14 2018-12-04 Snap Inc. Optical barcodes without orientation
US10579785B2 (en) 2017-09-29 2020-03-03 General Electric Company Automatic authentification for MES system using facial recognition
US10552667B1 (en) 2019-08-19 2020-02-04 Neon Evolution Inc. Methods and systems for image processing

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6327388B1 (en) * 1998-08-14 2001-12-04 Matsushita Electric Industrial Co., Ltd. Identification of logos from document images
US7410099B2 (en) * 2003-06-05 2008-08-12 Ntt Docomo, Inc. Apparatus and method for reading and decoding information contained in a barcode
US7412089B2 (en) * 2005-05-23 2008-08-12 Nextcode Corporation Efficient finder patterns and methods for application to 2D machine vision problems
US8868902B1 (en) * 2013-07-01 2014-10-21 Cryptite LLC Characteristically shaped colorgram tokens in mobile transactions

Also Published As

Publication number Publication date
US9111164B1 (en) 2015-08-18
KR20190104247A (en) 2019-09-06
US20220215193A1 (en) 2022-07-07
EP3248145A1 (en) 2017-11-29
KR102416030B1 (en) 2022-07-05
US10534949B1 (en) 2020-01-14
US20200117872A1 (en) 2020-04-16
KR20220098275A (en) 2022-07-11
US11308302B2 (en) 2022-04-19
KR102144391B1 (en) 2020-08-13
KR20200097002A (en) 2020-08-14
WO2016118338A1 (en) 2016-07-28
CN107430697A (en) 2017-12-01
US10068117B1 (en) 2018-09-04
KR20210063468A (en) 2021-06-01
KR102018143B1 (en) 2019-11-04
EP4184384A1 (en) 2023-05-24
US20160210545A1 (en) 2016-07-21
EP3248145A4 (en) 2017-12-13
US11675989B2 (en) 2023-06-13
US9659244B2 (en) 2017-05-23
CN107430697B (en) 2020-11-24
KR102257908B1 (en) 2021-05-28
CN112183536A (en) 2021-01-05
KR102514483B1 (en) 2023-03-27

Similar Documents

Publication Publication Date Title
US11675989B2 (en) Custom functional patterns for optical barcodes
US11321597B2 (en) Facial patterns for optical barcodes
US11671423B2 (en) Authentication via camera
US10607053B1 (en) Presenting an augmented reality within a custom graphic
US10410028B1 (en) Optical barcodes without orientation
KR20190055828A (en) Device pairing with optical cords
US11716336B2 (en) Data comprising encryption key
US10574732B2 (en) Data transfer using images on a screen

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
A107 Divisional application of patent