US20200302137A1 - Optimizing detection of images in relation to targets based on colorspace transformation techniques - Google Patents

Optimizing detection of images in relation to targets based on colorspace transformation techniques Download PDF

Info

Publication number
US20200302137A1
US20200302137A1 US16/690,064 US201916690064A US2020302137A1 US 20200302137 A1 US20200302137 A1 US 20200302137A1 US 201916690064 A US201916690064 A US 201916690064A US 2020302137 A1 US2020302137 A1 US 2020302137A1
Authority
US
United States
Prior art keywords
colors
colorspace
matrix
color
environment
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
US16/690,064
Other versions
US10796122B1 (en
Inventor
Austin Grant Walters
Jeremy Edward Goodsitt
Fardin Abdi Taghi Abad
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Capital One Services LLC
Original Assignee
Capital One Services LLC
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 Capital One Services LLC filed Critical Capital One Services LLC
Priority to US16/690,064 priority Critical patent/US10796122B1/en
Assigned to CAPITAL ONE SERVICES, LLC reassignment CAPITAL ONE SERVICES, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ABDI TAGHI ABAD, FARDIN, GOODSITT, JEREMY EDWARD, WALTERS, AUSTIN GRANT
Priority to US17/011,283 priority patent/US11314958B2/en
Publication of US20200302137A1 publication Critical patent/US20200302137A1/en
Application granted granted Critical
Publication of US10796122B1 publication Critical patent/US10796122B1/en
Priority to US17/706,758 priority patent/US11630968B2/en
Priority to US18/120,571 priority patent/US11954545B2/en
Priority to US18/616,267 priority patent/US20240232563A1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/0614Constructional details the marking being selective to wavelength, e.g. color barcode or barcodes only visible under UV or IR
    • 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
    • G06K9/4642
    • G06K9/4652
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/001Texturing; Colouring; Generation of texture or colour
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • G06T5/40Image enhancement or restoration using histogram techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/90Determination of colour characteristics
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • G06V10/50Extraction of image or video features by performing operations within image blocks; by using histograms, e.g. histogram of oriented gradients [HoG]; by summing image-intensity values; Projection analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • G06V10/50Extraction of image or video features by performing operations within image blocks; by using histograms, e.g. histogram of oriented gradients [HoG]; by summing image-intensity values; Projection analysis
    • G06V10/507Summing image-intensity values; Histogram projection analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • G06V10/56Extraction of image or video features relating to colour
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/46Colour picture communication systems
    • H04N1/56Processing of colour picture signals
    • H04N1/60Colour correction or control
    • H04N1/6002Corrections within particular colour systems
    • H04N1/6008Corrections within particular colour systems with primary colour signals, e.g. RGB or CMY(K)
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/46Colour picture communication systems
    • H04N1/64Systems for the transmission or the storage of the colour picture signal; Details therefor, e.g. coding or decoding means therefor
    • H04N1/644Systems for the transmission or the storage of the colour picture signal; Details therefor, e.g. coding or decoding means therefor using a reduced set of representative colours, e.g. each representing a particular range in a colour space
    • 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
    • G06K2019/06215Aspects not covered by other subgroups
    • G06K2019/06225Aspects not covered by other subgroups using wavelength selection, e.g. colour code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10016Video; Image sequence
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10024Color image
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20072Graph-based image processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/30Subject of image; Context of image processing
    • G06T2207/30204Marker
    • G06T2207/30208Marker matrix

Definitions

  • One aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment.
  • the apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: receive a representative dataset containing at least one of i) one or more images of a target and ii) one or more videos of the target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors, where the matrix is associated with the target.
  • Another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment.
  • the method includes: detecting a matrix on display via a physical medium and associated with an environment, where the matrix includes a plurality of non-black and non-white colors, where each one of the plurality of non-black and non-white colors are at least one of i) an absent color in relation to the environment and ii) a least prevalent color associated with the environment.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment.
  • the article of manufacture includes: a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors, where the matrix barcode is embedded with computer data, where the computer data is represented by a plurality of pixels associated with non-black and non-white colors, and where the plurality of pixels are associated with at least 3 color-channels forming the matrix barcode.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an ultraviolet layer.
  • the apparatus includes: receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors and at least one ultraviolet layer, where the matrix is associated with the target.
  • Yet another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment, where the matrix is part of an image that includes at least one ultraviolet layer.
  • the method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors and at least one ultraviolet layer, where the at least one ultraviolet layer reflects ultraviolet light, and where the matrix barcode includes four or more bits of information.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment, where the matrix barcode is part of an image with an ultraviolet layer.
  • the article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating ultraviolet light, where the matrix barcode includes a combination of four or more constituent matrix barcodes each associated with a distinct color-channel, including an ultraviolet color-channel associated with at least one layer of at least one of the four constituent matrix barcodes.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an infrared layer.
  • the apparatus includes: receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors and at least one infrared layer, where the matrix is associated with the target.
  • Yet another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment, where the matrix is part of an image that includes at least one infrared layer.
  • the method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors and at least one infrared layer, where the at least one infrared layer reflects infrared light, and where the matrix barcode includes four or more bits of information.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment, where the matrix barcode is part of an image with an infrared layer.
  • the article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating infrared light, where the matrix barcode includes a combination of four or more constituent matrix barcodes each associated with a distinct color-channel, including an infrared color-channel associated with at least one layer of at least one of the four constituent matrix barcodes.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix barcode that contains both an ultraviolet layer and an infrared layer.
  • the apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: create a matrix barcode using at least one infrared layer and at least one ultraviolet layer.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an infrared layer and an ultraviolet layer.
  • the apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: create a matrix barcode using one or more color layers, at least one infrared layer and at least one ultraviolet layer, receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, and determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the
  • Yet another aspect of the present disclosure includes a method for detecting a matrix barcode optimized for detection in a particular environment, where the matrix barcode includes both an ultraviolet layer and an infrared layer.
  • the method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors, at least one infrared layer, and at least one ultraviolet layer, and where the at least one ultraviolet layer reflects ultraviolet light, and where the at least one infrared layer reflects infrared light.
  • Yet another aspect of the present disclosure includes an article of manufacture for displaying a matrix barcode with both an ultraviolet layer and an infrared layer.
  • the article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating both infrared light and ultraviolet light, the matrix barcode including at least one infrared layer and at least one ultraviolet layer.
  • Yet another aspect of the present disclosure includes an article of manufacture for displaying a matrix barcode with both an ultraviolet layer and an infrared layer, and one or more colored layers optimized for detection in a particular environment.
  • the article of manufacture includes: a matrix barcode on display via a suitable surface reflecting both infrared light and ultraviolet light, the matrix barcode including at least one infrared layer, at least one ultraviolet layer, and a plurality of non-black and non-white colors, and where the plurality of non-black and non-white colors are associated with at least three non-white and non-black color-channels.
  • FIG. 1 illustrates an embodiment of a system to improve edge detection in images in accordance with at least one embodiment of the present disclosure.
  • FIG. 2A illustrates an embodiment of a clustering process for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 2B illustrates an embodiment of a colorspace conversion technique for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 3 illustrates an embodiment of a centralized system for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 4 illustrates an embodiment of an operating environment for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5A illustrates an embodiment of a first logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5B illustrates an embodiment of a second logic flow for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 5C illustrates an embodiment of a third logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5D illustrates an embodiment of a fourth logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 6A illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 6B illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 6C illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 7 illustrates a computer device for generating and scanning a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 8 illustrates an embodiment of a graphical user interface (GUI) for the system of FIG. 1 .
  • GUI graphical user interface
  • FIG. 9 illustrates an embodiment of a computing architecture.
  • FIG. 10 illustrates an embodiment of a communications architecture.
  • Various embodiments are directed to improving image processing by identifying which colorspace model is most appropriate to use for detection in a particular environment, e.g., to convert between colorspace(s) to improve detection within particular environments or in association with particular targets.
  • the conversion between colorspace(s) provides for a matrix located on an object or displayed by an electronic device, where the matrix is optimized for detection in an environment by performing one or more colorspace conversations in generating the matrix.
  • the matrix is a matrix barcode, and in one or more embodiments, the matrix barcode is a fiducial marker.
  • the colorspace conversion encodes information with respect to a matrix barcode, which permits proper scanning of the object associated with the matrix barcode, while preventing tampering and false verifications, e.g., the color-channels containing the information are tied to the conversion, and without having a scanning device accessing information related to the conversion, the scan cannot verify the object associated with the object and/or access any information associated therewith.
  • a colorspace conversion provides for increasing the amount of information stored on the matrix, e.g., matrix barcode, as the color-channels associated with the converted-to (derivative) colorspace can be increased as needed, without any limitation (provided the scanning equipment is suitably configured to make detections when the matrix is scanned).
  • ultraviolet and/or infrared layers can be used with respect to the matrix.
  • various embodiments of the present disclosure provide at least one of the following advantages: i) enhancing detection of an image, e.g., matrix, on an object in an environment, (as the matrix colors are selected and optimized with the colors of the environment in mind), ii) providing for a more secure verification, and iii) storing more information on the matrix, as there are no front-loaded limitations on how many color-channels can be employed, and the amount of information can be further increased, and a verification scan made more secure, by adding infrared or ultraviolet features.
  • the colorspace conversions improve edge detection.
  • edge detection is a known technical field and techniques for edge detection provide different results for different colorspace models. It is not unusual for one colorspace model to provide better results over another colorspace in edge detection because having image data in accordance with the colorspace model has a higher likelihood of success in edge detection than the other colorspace model.
  • Colorspace models are configured to represent color data, but most models differ in their representation of that color data.
  • the CIELAB or LAB colorspace model represents color as three values: L for the Luminance/Lightness and Alpha (A) and Beta (B) for the green-red and blue-yellow color components, respectively.
  • the LAB colorspace model is typically used when converting from a Red-Green-Blue (RGB) colorspace model into Cyan-Magenta-Yellow-Black (CMYK). For some images, representing its color data in the LAB colorspace model provides better edge detection results than other colorspace models including the RGB model.
  • the embodiments can improve affordability, scalability, modularity, extendibility, or interoperability for an operator, device or network that utilizes image detection as a means of verifying a transaction by providing a more effective and accurate manner of scanning an image associated with the verification (and by extension, minimizing redundant consumption of computer resources).
  • a procedure is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. These operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic or optical signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It proves convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be noted, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to those quantities.
  • the manipulations performed are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. No such capability of a human operator is necessary, or desirable in most cases, in any of the operations described herein which form part of one or more embodiments. Rather, the operations are machine operations. Useful machines for performing operations of various embodiments include general purpose digital computers or similar devices.
  • This apparatus may be specially constructed for the required purpose or it may comprise a general purpose computer as selectively activated or reconfigured by a computer program stored in the computer.
  • the procedures presented herein are not inherently related to a particular computer or other apparatus.
  • Various general purpose machines may be used with programs written in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these machines may appear from the description given.
  • FIG. 1 illustrates a block diagram for a system 100 .
  • the system 100 shown in FIG. 1 has a limited number of elements in a certain topology; it may be appreciated that the system 100 may include more or fewer elements in alternate topologies as desired for a given implementation.
  • the system 100 may implement some or all of the structure and/or operations for the system 100 in a single computing entity, such as entirely within a single device.
  • the system 100 may comprise an apparatus 120 .
  • the apparatus 120 may be generally arranged to process input 110 using various components and generate output 130 of which (some) output 130 is displayed on a display device or printed on a suitable material surface.
  • the apparatus 120 may comprise a processor 140 (e.g., processing circuit) and computer memory 150 .
  • the processing circuit 140 may be any type of logic circuit and the computer memory 150 may be a configuration of one or more memory units.
  • the apparatus 120 further includes logic 160 stored in the computer memory 150 and executed on the processing circuit 140 .
  • the logic 160 is operative to cause the processing circuit 140 to process image data of image datasets 170 into patched image data where the image data is being configured in accordance with a colorspace model.
  • the colorspace model as described herein refers to any suitable colorspace model, such as Red-Green-Blue (RGB), Cyan-Magenta-Yellow-Black (CMYK), Luminance-Alpha-Beta (LAB), and/or the like.
  • the Alpha and Beta channels of the LAB colorspace model refer to green-red and blue-yellow color components, respectively.
  • the green-red component may represent a variance between red and green with green in the negative direction, and red in the positive direction along an axis and the blue-yellow component may represent a variance between blue and yellow with blue in the negative direction and yellow in the positive direction along an axis.
  • an edge may be defined (mathematically) as each pixel location where the Alpha channel has a value of zero (0) or near zero.
  • the patched image data includes a plurality of patches of which each patch comprises color data (e.g., pixel data where each pixel is represented as a tuple of Red-Green-Blue (RGB) color intensities).
  • color data e.g., pixel data where each pixel is represented as a tuple of Red-Green-Blue (RGB) color intensities.
  • RGB Red-Green-Blue
  • one colorspace model e.g., RGB
  • Some images provide optimal or near-optimal edge detection results when arranged in RGB while other images provide optimal or near-optimal edge detection results when arranged in LAB or an XYZ colorspace and vice versa.
  • the logic 160 is further operative to cause the processing circuit 140 to apply the colorspace transform mechanism 180 to the image data to generate the transformed image data in accordance with the other colorspace model. Then, the logic 160 is operative to cause the processing circuit 140 to apply an edge detection technique 190 to the transformed image data.
  • the edge detection technique 190 is an image processing technique that refers to any one of a number of algorithms for identifying edges or boundaries of objects within images. In general, the edge detection technique 190 provides information (e.g., pixel data) indicating positions of edges in the image data of the image datasets 170 .
  • Some implementations of the edge detection technique 190 operate by detecting discontinuities in brightness and, for those implementations, having the image data in a LAB colorspace, or XYZ colorspace over RGB provides more precise edge detection results. Some implementations of the edge detection technique 190 provide accurate edge detection results when the image data is modeled according to HCL (Hue-Chroma-Luminance) instead of RGB.
  • HCL Human-Chroma-Luminance
  • the logic 160 is further operative to cause the processing circuit 140 to identify an image group corresponding to the patched image data.
  • the image datasets 170 further includes image group model data correlating images with a colorspace model most likely to provide appropriate edge detection results.
  • the image group model data indicates which colorspace model to use in transforming a given image prior to edge detection to achieve near-optimal edge detection results.
  • the logic 160 is further configured to cause the processing circuit 140 to select a colorspace transform mechanism 180 based upon the image group.
  • the colorspace transform mechanism 180 is operative to transform the image data into transformed image data in accordance with another colorspace model, the other colorspace model having a higher likelihood than the colorspace model at edge detection for the image group. It is appreciated that the other colorspace model may be any colorspace model including those with a different number of channels than the colorspace model.
  • the logic 160 can be further operative to cause the processing circuit 140 to determine a colorspace that is optimal for detection in association with a particular object, entity, or environment, where a colorspace or histogram representation of the particular object, entity or environment can be part of the image datasets 170 .
  • the logic 160 can be further operative to cause the processing circuit 140 to determine the optimal colorspace based on one or more colorspace conversion operations, where the colorspace conversion operations can provide a mechanism for encoding information in any suitable medium, including but not limited to a matrix, such as a matrix barcode, a fiducial marker, any other suitable barcode, or any other suitable image.
  • the logic 160 can be further operative to cause the processing circuit 140 to generate a scheme for a matrix, e.g., a matrix barcode, fiducial marker, etc. based on the colorspace determination and for detection in relation to the particular object, entity, or environment.
  • the logic 160 can further be operative to cause the processing circuit 140 to provide for a scheme to add at least one ultraviolet layer and infrared layer to an image, such as a matrix or matrix barcode, useful for detection in relation to the particular object, entity, or environment, where the ultraviolet layer and/or infrared layer add additional data carrying capacity and/or security to the detectable image.
  • the one or more colorspace models as described herein, as stated and implied elsewhere herein, refers to any suitable colorspace model, such as colorspace employing a tristimulus system or scheme, the Red-Green-Blue (RGB), the Luminance-Alpha-Beta (LAB), an XYZ colorspace, and/or the like and/or variations of the same.
  • RGB Red-Green-Blue
  • LAB Luminance-Alpha-Beta
  • XYZ colorspace XYZ colorspace
  • one colorspace model (e.g., RGB or XYZ) may correspond to a higher likelihood of success in edge detection than another colorspace model in terms of detection of a displayed or printed image, e.g. barcode, in relation to an object, entity, or environment with a particular color distribution.
  • particular colors and color-channels associated with a colorspace may offer superior edge detection in relation to the object, entity, or environment.
  • an image depicting a red balloon on a green field would appear much different in RGB than in LAB; therefore, with respect to edge detection, LAB would provide a higher likelihood than RGB at successfully identifying and locating edges (e.g., boundaries) of the red balloon, or a matrix, e.g., barcode or fiducial marker, that had a red color in the green environment.
  • edges e.g., boundaries
  • a matrix e.g., barcode or fiducial marker
  • a color-channel is a distribution of colors with a first color and second color of first and second highest prevalence, respectively, where the first color becomes a minimum in the color channel and the second color becomes the maximum such that the boundary may be a transition between these colors.
  • This boundary may be at least one pixel where the color changed from the first to the second color or vice versa. If the first color is set to zero (0) and the second color is set to two hundred and fifty-five (255), then, mathematically, this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255.
  • color-channels e.g., “R,” “G,” and “B” define a colorspace such as RGB (e.g., a first colorspace based on a tristimulus system), and in various embodiments custom color-channels can be created using a (second) tristimulus system associated with and defining an XYZ colorspace (and/or conversions to an XYZ colorspace). In various embodiments, the color-channels can be greater than three.
  • one or more color-channel ranges are selected such that a maximum color value of one or more color channel corresponds to a unique color value, most prevalent color value, and/or highest color value of a target object, entity, and/or environment associated with a scan and the minimum color value of the color-channel corresponds to a most unique color, most prevalent color value and/or highest color value of the scannable image, e.g. matrix, matrix barcode, and/or fiducial marker, where additionally, the most prevalent value and/or highest color value of the scannable image is also a least prevalent (lowest color value) and/or absent from the target object, entity, and/or environment associated with the scan, or visa-versa (e.g. with respect to the maximum or minimum values).
  • the most prevalent value and/or highest color value of the scannable image is also a least prevalent (lowest color value) and/or absent from the target object, entity, and/or environment associated with the scan, or visa-versa (e.g. with respect to the maximum or minimum values).
  • the logic 160 is further operative to cause the processing circuit 140 to identify an image group corresponding to the patched image data.
  • the image datasets 170 further includes image group model data correlating images with a colorspace transform model most likely to provide appropriate edge detection results.
  • the image group model data indicates which colorspace transform model to use in transforming a given image prior to edge detection in order to achieve near-optimal edge detection results.
  • the logic 160 is further configured to cause the processing circuit 140 to select a colorspace transform mechanism 180 based upon the image group.
  • the colorspace transform mechanism 180 is operative to transform the image data into transformed image data in accordance with another colorspace model, the other colorspace model having a higher likelihood than the colorspace model at edge detection for the image group.
  • the system 100 can include one or more of a camera or video device 195 and/or a scanning device 197 , where both device 195 and device 197 can be any suitable device for obtaining, capturing, editing, and/or scanning images, including but not limited to video or camera pictures, of objects, entities, and/or environments.
  • the logic 160 can be configured to capture or scan images of a particular object, entity or environment using device 195 and/or device 197 , where the captured images can become part of image datasets 170 and used for determining suitable colorspaces, performing colorspace conversions, and/or scanning images determined from colorspace conversions, as may be consistent with the teachings provided herein.
  • the system 100 can include a printing device 199 (e.g. printer) or an application for the same, where images part of image datasets 170 and/or images generated by one or more components of system 100 , by applying a colorspace transformation technique or mechanism, such as a scannable matrix, matrix barcode, or fiducial marker can be printed by printing device 199 and/or printing device 199 can provide a scheme for another device to print or generate an image in association with the scannable matrix, matrix barcode, or fiducial marker.
  • a printing device 199 e.g. printer
  • an application for the same where images part of image datasets 170 and/or images generated by one or more components of system 100 , by applying a colorspace transformation technique or mechanism, such as a scannable matrix, matrix barcode, or fiducial marker can be printed by printing device 199 and/or printing device 199 can provide a scheme for another device to print or generate an image in association with the scannable matrix, matrix barcode, or fiducial marker.
  • FIG. 2A illustrates an embodiment of a clustering process 200 A for the system 100 .
  • the clustering process 200 A operates on image datasets (e.g., the image datasets 170 of FIG. 1 ) storing color data for images.
  • color data 202 of an image undergoes a patching operation where the image is processed into a plurality of patches 204 of patched image data 206 .
  • Each patch 204 of the patched image data 206 includes color data in accordance with a colorspace model, such as pixel data having RGB tuples.
  • the clustering process 200 A further processes the patched image data 206 , via a transformation operation 208 , by applying a colorspace transform mechanism on the color data of the patched image 206 to transform patched image data into transformed image data of a transformed image 210 .
  • the color data of the patched image 206 is configured in accordance with the colorspace model and new color data for the transformed image 210 is generated according to another colorspace model.
  • the clustering process 200 A performs a mini-colorspace transform for at least one patch of the patched image 206 , possibly leaving one or more patches without a transformation. Via the transformation operation 208 , the mini-colorspace transform modifies the color data in the at least one patch to transform patched image data into transformed image data of a transformed image 210 .
  • the clustering process 200 A may perform stitching between patches to make the patched image 206 uniform as opposed to creating artificial edges.
  • FIG. 2B illustrates an example of a colorspace conversion scheme 200 B in accordance with various embodiments of the present disclosure.
  • a histogram 218 representation of a particular object, entity, or environment 215 is provided (where the numbers 100, 90, 80, and 70 are intended to represent a simplified version of colors distribution values of one or more colors representing the particular object, entity, or environment 215 ).
  • the histogram 218 can be generated by having one or more components of system 100 performing a scan of the particular object, entity, or environment 215 and generating a histogram 218 of the most prevalent colors, least prevalent colors, or absent colors of the object, entity, or environment 215 .
  • the histogram 218 can be of four or more colors of the most prevalent colors of the object, entity, or environment. Since various embodiments of the present disclosure expressly contemplate using colors imperceptible to the human eye, there is no limitation on the number of colors that can be used with respect to the histogram 218 , the colorspace conversions discussed herein, or any images generated from the colorspace conversions, including but not limited to a matrix, matrix barcode, fiducial marker, etc. can have in excess of four colors and four color-channels, where the four colors and/or four color-channels are distinct and different with respect to one another.
  • one or more components of system 100 can determine the most prevalent colors associated with the object, entity, or environment 215 , and the resulting histogram 218 may be based on that determination.
  • the histogram 218 can be used to map the most prevalent colors to a distribution 222 associated with a suitable colorspace 224 , including but not limited to an RGB colorspace 224 .
  • the colors of histogram 218 are mapped pursuant to the tristimulus values of the RGB colorspace, e.g., “R,” “G,” and “B.” Any suitable mathematical conversion, e.g., linear-algebraic, etc. can be used to map the conversion to the RGB colorspace, e.g., convert the mapped RGB colorspace to another colorspace.
  • one or more components of system 100 can convert the RGB distribution 222 to a new colorspace 226 with a distribution 228 pursuant to the new colorspace 226 .
  • Any suitable colorspace conversion can be used, including converting to an XYZ colorspace, where the conversion can be pursuant to any suitable mathematical conversions and equations that govern the XYZ colorspace, including suitable tristimulus conversions between RGB and XYZ.
  • “Y” represents a luminance value of the XYZ space and at least one of “X” and “Z” (or both) represent a chrominance value of the colorspace and an associated distribution, e.g. 226 plotted pursuant to the XYZ colorspace.
  • the luminance channel “Y” is filtered out resulting in colorspace 228 ′ and distribution 226 ′, which can assist in making determinations solely on actual chromatic values associated with the entity, object, or environment 215 , without considering luminance (this is helpful at least because colors can be used that are imperceptible to the human eye).
  • four (or more) lines can be defined by points (a1, b1), (a2, b2), (a3, b3), and (a4, b4), and are selected to have a maximum distance apart with respect to distribution 226 ′.
  • the points a1, a2, a3, and a4 are selected to correspond to the most prevalent colors associated with entity, object, or environment 215 and b1, b2, b3, and b4 by extension, being opposite to those colors, may represent the least prevalent or absent colors in association with an entity, object, or environment b1, b2, b3, b4.
  • These lines may define vectors for a new colorspace conversion in an XYZ or other suitable colorspace 245 and may form the basis for new XYZ tristimulus values.
  • An image such as a matrix or matrix barcode
  • the colors may correspond to less prevalent or absent colors in relation to where a potential scan may occur (or what is being scanned), e.g., a matrix barcode on an entity or object and/or in an environment with colors that have a maximum difference in relation thereto, edge detection is enhanced.
  • the maximum distance from the most prevalent colors to least prevalent colors can be determined, e.g., a1 to b1, a2 to b2, etc., and then lines can be drawn from b1, b2, b3, and b4 in a direction tangential, parallel or opposite a vector or direction associated with a1, a2, a3, and a4.
  • the color-channel vectors (i, ⁇ i), (j, ⁇ j), (k, ⁇ k), an additional color-channel and all other color-channels (omitted from display due to the limitations of three-dimensional space) associated with colorspace 250 may be entirely colors absent and/or mildly prevalent in relation to entity, object, or environment 215 , which can further enhance edge detection.
  • the color-channel vectors when performing the colorspace conversion between 228 ′ and 250 , in addition to carrying out the algebraic or other suitable conversions associated with the XYZ colorspace, the color-channel vectors, e.g. (i, ⁇ i), (j, ⁇ j), (k, ⁇ k), may be orthogonal to one another by performing any suitable mathematical and/or orientation operation on the vectors and/or by selecting suitable points on colorspace 226 ′ and distribution 228 ′ when making the conversion.
  • a second maximum difference between one or more points can be taken in space 250 , in addition to an orientation operation to center the distribution 245 along the axis of the newly defined color-channel vectors, e.g.
  • performing at least one of the orthogonality operation, maximum determination, and/or orienting operation can further enhance edge detection of an image generated for scanning, such as a matrix barcode, in relation to an entity, object, or environment 215 to be scanned.
  • the various color-channels described above including each vector, e.g. ( ⁇ i, i), defines a first color that is a minimum in the color channel and the second color becomes the maximum.
  • This boundary may be at least one pixel where the color changed from the first to the second color or vice versa. If the first color is set to zero (0) and the second color is set to two hundred and fifty-five (255), then, mathematically, this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255.
  • the boundary is such it may be a transition between these colors where, as discussed above, one or more color-channel ranges are selected such that a maximum color value of one or more color channel corresponds to a unique color value, most prevalent color value, and/or highest color value of a target object, entity, and/or environment associated with a scan and the minimum color value of the color-channel corresponds to a most unique color, most prevalent color value and/or highest color value of the scannable image, e.g.
  • the most prevalent value and/or highest color value of the scannable image is also a least prevalent (lowest color value) and/or absent from the target object, entity, and/or environment associated with the scan, or visa-versa (e.g. with respect to the maximum or minimum values).
  • the length of the color-channel can be adjusted accordingly based on the capabilities of the scanning and image-acquiring abilities of the various components, e.g. camera or video device 195 , scanning device 197 , and/or recognition component 422 - 4 (discussed below with respect to FIG. 4 ), where the length increases the number of different colors between the minimum and maximum point of the color channel.
  • the value of “X,” “Y,” and “Z,” is dependent on the input colors from the RGB colorspace (or in the case of a second conversion, from the converting colorspace).
  • the tristimulus values are three be definition, as noted above, the conversion can involve more than three color-channels, including color-channels that define colors imperceptible to the human eye.
  • the conversion governed by Equation. 1 can form a key for a scanning device to scan an image defined by the conversion, such as a matrix, e.g., matrix barcode or fiducial marker.
  • the logic 160 of system 100 can cause a processor 140 (or an application programmed to carried out the operations of 100 ) to provide a scanning device 197 with a key governed by Equation 1 in order to scan an image that is encoded pursuant to one or more colorspace conversions associated with Equation 1.
  • the logic 160 of system 100 can cause a processor 140 to provide a scheme for adding either one or both of an ultraviolet layer and/or an infrared layer to an image, such as a matrix, e.g. matrix barcode or fiducial marker, where the image contains more than one non-black or non-white colors governed by any suitable colorspace.
  • the scheme may include both an ultraviolet layer and an infrared layer, where the ultraviolet layer may form the first layer of an image in order to take advantage of its properties.
  • the non-black and non-white colors of the scannable image may be determined by one or more colorspace conversion techniques as outlined herein.
  • Non-black and non-white colors means colors that are not black or white.
  • non-black and non-white colors means colors that are not black, white or based on a greyscale distribution.
  • FIG. 3 illustrates a block diagram of a distributed system 300 .
  • the distributed system 300 may distribute portions of the structure and/or operations for the system 100 across multiple computing entities.
  • Examples of distributed system 300 may include without limitation a client-server architecture, a 3-tier architecture, an N-tier architecture, a tightly-coupled or clustered architecture, a peer-to-peer architecture, a master-slave architecture, a shared database architecture, and other types of distributed systems.
  • the embodiments are not limited in this context.
  • the distributed system 300 may comprise a client device 310 and a server device 320 .
  • the client device 310 and/or the server device 320 may be the same or similar to the apparatus 120 as described with reference to FIG. 1 .
  • the client device 310 and the server device 320 may each comprise a processing component 330 which is the same or similar to the processing circuit 140 as described with reference to FIG. 1 .
  • the devices 310 , 320 may communicate over a communications media 312 using communications signals 314 via a communications component 340 .
  • the server device 320 may communicate with other devices over the communications media 312 , using communications signals 314 , via the communications component 340 .
  • the other devices may be internal or external to the device 320 as desired for a given implementation.
  • the client device 310 may comprise or employ one or more client programs that operate to perform various methodologies in accordance with the described embodiments.
  • the client device 310 may implement the system 100 including the logic 160 of FIG. 1 , where in various embodiments, the client device 310 can implement one or more operations to form an image based on one or more colorspace conversions as outlined above and herein.
  • the server device 320 may comprise or employ one or more server programs that operate to perform various methodologies in accordance with the described embodiments.
  • the server device 320 may implement the clustering process 200 A of FIG. 2A and generate image group model data 350 and/or generate image group model data 350 by performing one or more of the colorspace conversion operations of scheme 200 B.
  • the image group model data 350 can include a printing scheme or color distribution for an image to be scanned in an entity, object, or environment 215 , such as a matrix, e.g., matrix barcode or fiducial marker.
  • the devices 310 , 320 may comprise any electronic device capable of receiving, processing, and sending information for the system 100 .
  • Examples of an electronic device may include without limitation an ultra-mobile device, a mobile device, a personal digital assistant (PDA), a mobile computing device, a smart phone, a telephone, a digital telephone, a cellular telephone, ebook readers, a handset, a one-way pager, a two-way pager, a messaging device, a computer, a personal computer (PC), a desktop computer, a laptop computer, a notebook computer, a netbook computer, a handheld computer, a tablet computer, a server, a server array or server farm, a web server, a network server, an Internet server, a work station, a mini-computer, a main frame computer, a supercomputer, a network appliance, a web appliance, a distributed computing system, multiprocessor systems, processor-based systems, consumer electronics, programmable consumer electronics, game devices, television, digital television, set top box, wireless access point,
  • the devices 310 , 320 may execute instructions, processing operations, or logic for the system 100 using the processing component 330 .
  • the processing component 330 may comprise various hardware elements, software elements, or a combination of both. Examples of hardware elements may include devices, logic devices, components, processors, microprocessors, circuits, processing circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), Application-specific Standard Products (ASSPs), System-on-a-chip systems (SOCs), Complex Programmable Logic Devices (CPLDs), memory units, logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth.
  • ASIC application specific integrated circuits
  • PLD programmable logic devices
  • DSP digital signal processors
  • FPGA field programmable gate array
  • ASSPs Application-specific Standard Products
  • Examples of software elements may include software components, programs, applications, computer programs, application programs, system programs, software development programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints, as desired for a given implementation.
  • the devices 310 , 320 may execute communications operations or logic for the system 100 using communications component 340 .
  • the communications component 340 may implement any well-known communications techniques and protocols, such as techniques suitable for use with packet-switched networks (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), circuit-switched networks (e.g., the public switched telephone network), or a combination of packet-switched networks and circuit-switched networks (with suitable gateways and translators).
  • the communications component 340 may include various types of standard communication elements, such as one or more communications interfaces, network interfaces, network interface cards (NIC), radios, wireless transmitters/receivers (transceivers), wired and/or wireless communication media, physical connectors, and so forth.
  • communication media 312 include wired communications media and wireless communications media.
  • wired communications media may include a wire, cable, metal leads, printed circuit boards (PCB), backplanes, switch fabrics, semiconductor material, twisted-pair wire, co-axial cable, fiber optics, a propagated signal, and so forth.
  • wireless communications media may include acoustic, radio-frequency (RF) spectrum, infrared and other wireless media.
  • FIG. 4 illustrates an embodiment of an operational environment 400 for the system 100 .
  • the operating environment 400 includes an application 420 , such as an enterprise software application, for processing input 410 and generating output 430 .
  • an application 420 such as an enterprise software application
  • the application 420 comprises one or more components 422 - a where a represents any integer number.
  • the application 420 may comprise an interface component 422 - 1 , a clustering component 422 - 2 , a transform mechanism library 422 - 3 , and a recognition component 422 - 4 .
  • the interface component 422 - 1 may be generally arranged to manage a user interface for the application 420 , for example, by generating graphical data for presentation as a Graphical User Interface (GUI).
  • GUI Graphical User Interface
  • the interface component 422 - 1 may generate the GUI to depict various elements, such as dialog boxes, HTML forms having rich text, and/or the like.
  • the clustering component 422 - 2 may be generally arranged to organize images into image groups or clusters. Some embodiments of the clustering component 422 - 2 execute the clustering process 200 A of FIG. 2A and/or one or more of the colorspace conversion operations of scheme 200 B of FIG. 2B and generates the image group model data 350 of FIG. 3 . In various embodiments, the clustering component 422 - 2 identifies, for each image group, a particular colorspace transform having a higher likelihood than a current colorspace transform of success in edge detection for that group as outlined herein or otherwise suitable.
  • the clustering component 422 - 2 may perform the above-mentioned clustering process for a variety of edge detection techniques, resulting in sets of image groups where each set of image groups corresponds to a particular technique.
  • Edge detection techniques vary in how boundaries are identified in an image; some techniques detect differences in color whereas other techniques measure another attribute. Some techniques differ with respect to how color differences are even measured. It is possible for one technique to alter certain steps and create multiple techniques.
  • the colorspace transform library 422 - 3 includes a plurality of colorspace transform mechanisms and may be generally arranged to provide a colorspace transform mechanism for application on an image, transforming that image into a transformed image in accordance with a different colorspace model than the image's original colorspace model.
  • the colorspace model refers to a technique for modeling an image's color data, such as in RGB or in LAB, or RGB to XYZ, or RGB to XYZ to another XYZ.
  • the colorspace transform mechanism performs mathematical operations to map a data point within the image's original/current colorspace model into a corresponding datapoint in accordance with the different colorspace model.
  • the colorspace transform may convert an RGB pixel having a tuple of RGB values into a LAB pixel having a tuple of LAB values, an RGB pixel having a tuple of RGB values into an XYZ pixel having a tuple of XYZ values, and/or an RGB pixel having a tuple of RGB values into an XYZ pixel having a tuple of XYZ values and again into another XYZ pixel having a tuple of other XYZ values.
  • the pixels associated with the final conversion can define a color distribution for a scannable image, such as a matrix or matrix barcode that is used for a scan in association with an entity, object, or environment.
  • the recognition component 422 - 4 such as a suitable scanner, printer and/or camera or application for the same, may be generally arranged to execute an edge detection technique as part of a recognition operation on the transformed image.
  • a recognition operation is Optical Character Recognition (OCR).
  • OCR Optical Character Recognition
  • the application 420 invokes the recognition component 422 - 4 to perform various tasks including scanning a matrix, e.g., matrix barcode or fiducial marker, for verifying an authenticity of an item and/or to obtain encoded information associated with the barcode.
  • the recognition component 422 - 4 can be configured to contain a key, e.g.
  • a mathematical equation or equations with specified inputs defining a colorspace conversion such that it scans relevant colors reflected by the barcode, where the colors are based on one or more colorspace transformation techniques as outlined herein, where the key defines a final transformation that defines color-channels and a colorspace associated with colors of the scannable image, and where color-channels defined by the key each represent at least one bit of encoded data.
  • the recognition component 422 - 4 can print or provide a schema for printing an image, e.g., barcode and/or fiducial marker, that contains one or more non-black and non-white colors and one or both of an ultraviolet layer and an infrared layer.
  • the color-channels associated with each non-black and non-white color each can constitute at least one bit of data, and each one of the infrared and ultraviolet layers can each constitute one bit of data.
  • each one of the non-black and non-white colors are generated by a colorspace transformation mechanism or technique and are scannable by a key associated with the transformation mechanism.
  • the number of color-channels can be adjusted to be greater than or equal to four color-channels, as the recognition component 422 - 4 can be adjusted to scan any number of colors, including colors not perceptible to the human eye.
  • the non-black and non-white color-channel can be used in conjunction with one or both of the infrared or ultraviolet layers on a scannable image, such as a matrix, matrix barcode and/or fiducial marker, where each of one of the color-channels, ultraviolet layer(s), and/or infrared layer(s) represent a bit of data and a different manner of encoding data into the image, and as such, six or more bits of data can be encoded into the image.
  • the ultraviolet layer may be printed or displayed first in relation to the infrared layers and the various layers associated with non-black and non-white color-channels to take advantage of the ultraviolet layer's properties.
  • the image containing all or one of the layers associated with the non-black and non-white color-channel layers, the ultraviolet layers, and the infrared layers can be scanned by the recognition component 422 - 4 for a verification component, where the recognition component 422 - 4 may contain or receive a key that is based on an equation related to a colorspace conversion, e.g. Equation 1, where the colorspace conversion reveals the relevant color-channels with associated colors containing the information, in addition to one or more verification bits indicating whether the presence or absence of an ultraviolet and/or infrared layer is indicative of encoded information. Accordingly, the key and/or verification bit provides a manner of decoding information.
  • application 420 is configured to contain the key and/or verification bit and provide an output 430 once the scan of the image, e.g., barcode, is verified locally.
  • the recognition component 422 - 4 can require an additional verification step of contacting a host system that contains one or more of the functionalities of system 100 , to confirm, e.g., by one or more comparison steps, that the key and/or verification bit used by the recognition component 422 - 4 is accurate. If the key is accurate, and the scan is confirmed by the recognition component 422 - 4 , then the output 430 of application 420 is one or more access, transfer, or receipt of information, including currency, personal, and/or financial information, to another entity.
  • scanning the image e.g., matrix, a matrix barcode, and/or fiducial marker can be done to protect a user from financial misappropriation.
  • the recognition component 422 - 4 may perform the text or image recognition operation to determine whether the image, e.g., barcode, is valid, and relates the validity of the scan to a verification or access of information that includes any sensitive information, such as a password or social security number (SSN), according to some embodiments.
  • the application 420 may invoke the recognition component 422 - 4 to scan an image, e.g. a barcode, prior to publishing social network content such that a potential failure to properly scan the image, e.g.
  • the component scanning the image does not have a key that properly decodes it pursuant to the key related to the colorspace information and/or the bit indicating that an ultraviolet and/or infrared layer contains information, identification of sensitive information in that content prevents said publishing.
  • the scanning of the image e.g., barcode
  • FIG. 5A illustrates one embodiment of a logic flow 500 A.
  • the logic flow 500 A may be representative of some or all of the operations executed by one or more embodiments described herein.
  • the logic flow 500 A receives a representative dataset of a target, such as an entity, object, or environment 502 .
  • the logic flow 500 may receive a representative dataset containing at least one of i) one or more images of a target and ii) one or more videos of the target, the target including at least one of i) an environment, ii) a live entity and iii) an object using any suitable camera or scanning device, where the representative dataset is contained in image group model data 350 or obtained directly by scanning the target using any suitable device, e.g., camera or video device 195 and/or scanning device 197 .
  • the target may be an environment that contains a scannable image therein.
  • the logic flow 500 A may process the representative dataset into a suitable representation of a color scheme, such as a histogram 504 .
  • the logic flow 500 may examine image group model data 350 , which contains captured data of a scanned environment. Once the logic flow 500 identifies the scanned data of the environment, the logic flow can process that data into a histogram of a particular colorspace, e.g., an RGB colorspace.
  • the logic flow 500 A may identify the most prevalent colors of the environment utilizing the histogram 506 .
  • the logic flow identifies the most prevalent colors in order to apply a colorspace transform mechanism for substantially maximizing edge detection for a scannable image, such as a matrix, matrix barcode, fiducial marker, etc.
  • the logic flow 500 A may determine a related number of colors based on the histogram 508 , e.g., the histogram is used to map to a first colorspace, where least prevalent and/or absent colors in relation to the most prevalent colors of the target are determined, and the least prevalent and/or absent colors form the basis for one or more color-channels in a second colorspace.
  • the related plurality of colors can represent a range of colors between the most prevalent colors and the least prevalent colors and/or absent colors of the target, including sole colors that are absent in relation to the target and/or colors that are the least prevalent in association with the target.
  • the logic flow may select and apply a colorspace transform mechanism to the image data associated with the histogram.
  • the image data includes color data configured in accordance with a colorspace model, e.g., the histogram can be used to create a colorspace representation of the target data.
  • the logic flow 500 applies the colorspace transform mechanism 180 of FIG.
  • the logic flow may create a histogram of the image data associated with the target, then use the histogram to create a first colorspace representation of the target, e.g., an RGB colorspace representation. Thereafter, as discussed below, the logic flow can perform one or more additional colorspace transformation techniques into other colorspaces, such as XYZ colorspaces or any other suitable colorspace that utilizes a tristimulus system.
  • the logic flow 500 A may perform a colorspace transform manipulating the color data of the original image data to enable efficient edge detection on the transformed image data. As explained below, the logic flow 500 A may change the colorspace model to quickly identify boundaries, such as when two colors are close in proximity. The logic flow 500 A examines each datapoint in the image, and for each location, the logic flow 500 A identifies a color.
  • the colorspace conversion can be based on at least one set of color coordinates for each one of the most prevalent colors according to the another (or second) colorspace and determining at least one set of color coordinates corresponding to the related plurality of colors in the (second) another colorspace, where the at least one set of coordinates of the most prevalent plurality of colors being either one or both of perpendicular/orthogonal and a maximal distance away, with respect to another colorspace, to the at least one set of coordinates of the related colors.
  • the second colorspace can be considered a derivative colorspace of the first color space.
  • this ensures that the colors used for a scannable image may maximize edge detection, as the maximal distance away between prevalent color-channels and colors of the target in the environment and other color-channels and colors (the related color-channels and colors) ensures that the related color-channels and colors are either absent in the target and/or least prevalent in the target. Additionally, if the related colors and color-channels are selected to be perpendicular or orthogonal in relation to the target color-channels and colors (and with respect to one another), this may further enhance edge detection.
  • the logic flow 500 A proceeds to identify two or more colors by prevalence in the target and configures them into one channel. Take, for instance, a first color and second color of first and second highest prevalence, respectively, where the first color becomes a minimum in the color channel and the second color becomes the maximum such that the boundary may be a transition between these colors. This boundary may be at least one pixel where the color changed from the first to the second color or vice versa.
  • this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255.
  • these color-channels can correspond to a first colorspace, e.g., RGB, where the first colorspace can be based on the first set of tristimulus values, and where the first-colorspace may have a color coordinates for representing colors of the target, e.g., the most prevalent colors of the target.
  • a first colorspace e.g., RGB
  • the first colorspace can be based on the first set of tristimulus values
  • the first-colorspace may have a color coordinates for representing colors of the target, e.g., the most prevalent colors of the target.
  • the logic flow 500 A may then identify one or more colors that are either unused or barely used (i.e., least prevalent or absent) and establish those colors in another channel to be opposite of the above-identified prevalent colors, where the new color-channel (or color-channels) forms the basis for a new colorspace, e.g., a new set of tristimulus values of an XYZ colorspace, and where the first colorspace is converted to the second colorspace.
  • a new colorspace e.g., a new set of tristimulus values of an XYZ colorspace
  • the logic flow 500 A may perform one or more additional operations, e.g. configuring each color-channel of the new colorspace to be perpendicular or orthogonal to one another in the new colorspace model, make an additional conversion to a third colorspace, including an intermediary operation that filters out non-chromacity related features such as luminance or brightness channel, and/or perform an orientation operation in the second (or third) colorspace prior to making the color-channels perpendicular or orthogonal to each other (in order to maximize the distance between color-channels and thus enhancing edge detection).
  • additional operations e.g. configuring each color-channel of the new colorspace to be perpendicular or orthogonal to one another in the new colorspace model, make an additional conversion to a third colorspace, including an intermediary operation that filters out non-chromacity related features such as luminance or brightness channel, and/or perform an orientation operation in the second (or third) colorspace prior to making the color-channels perpendicular or orthogonal to each other (in order to maximize the distance between
  • the logic flow 500 A may utilize the related colors of block 508 to create one or more scannable images 510 , such as a matrix, matrix barcode, fiducial marker, or any other suitable image for scanning.
  • the related colors may be colors of each color-channel associated with the final colorspace conversion as discussed above, e.g. a plurality of color-channels and associated colors, as may be represented in an XYZ colorspace, that are either not prevalent in the target and/or are completely absent in the target, where, in various embodiments, the least prevalent and/or absent colors can be arranged orthogonally to each other to further enhance edge detection.
  • the scannable image may be a matrix barcode that is formed to reflect colors of each of the least prevalent and/or absent and/or orthogonal color-channels in relation to a target, e.g., environment containing the matrix barcode.
  • the matrix barcode is embedded with information that is based on the colorspace conversions, e.g., each pixel or pixels associated with the matrix bar code is associated with a color-channel of the final colorspace, e.g. the XYZ colorspace with color-channels representing the least prevalent or absent colors of the environment, where each color-channel represents a bit of data, and where the number of color-channels can be three or more, four or more, etc. (as there are no limitations imposed by human perceptibility), and by extension the number of encoded bits can be three or more, four or more, etc.
  • each one of the four or more colors are distinct colors in relation to one another, and based on the colorspace techniques discussed herein and above, the four or more colors are derived from a plurality of coordinates corresponding to each one of the at least four distinct colors along a converted-to (derivative) colorspace, where the converted-to (derivative) colorspace contains a plurality of coordinates sets representing the at least four prevalent colors of the target, e.g., environment, and each of the four or more colors corresponds to a distinct coordinate set of the converted-to (derivative) colorspace.
  • each of the four or more distinct colors are selected based on having a maximal opposite coordinate relationship with respect to at least one of the plurality of coordinate sets representing at least four prevalent colors in the target, e.g., environment.
  • edge detection technique 190 may be appropriate for the one colorspace model of the transformed image data while another edge detection technique may be appropriate for the original colorspace model.
  • the embodiments are not limited to this example.
  • FIG. 5B illustrates one embodiment of a logic flow 500 B.
  • the logic flow 500 B may be representative of some or all of the operations executed by one or more embodiments described herein.
  • the logic flow may detect a matrix that includes one or more non-black and non-white colors, where each of the non-black and non-white colors is i) at least one of an absent color in relation to an environment and/or ii) at least one least prevalent color associated with the environment 515 .
  • the matrix is a barcode constructed with one or more colorspace conversion techniques as outlined herein, e.g., the matrix barcode is derived from an RGB colorspace and a derivative colorspace of the RGB colorspace (a converted-to (derivative) colorspace from the RGB colorspace, such as an XYZ colorspace).
  • the derivative colorspace is an XYZ colorspace with a filtered luminance channel.
  • the barcode can be scanned with any suitable component, e.g., a scanning device 197 , that has a suitable key, e.g., tristimulus equations associated with a conversion to an XYZ colorspace, that reveals the color-channels with associated colors that are associated with the scannable portions of the matrix barcode, including, in various embodiments, information encoded in the matrix barcode.
  • the barcode can include four or more distinct colors each associated with at least four-distinct color-channels, where each of the colors is different from one another and different from the most prevalent colors of the environment.
  • the colors and color-channels of the barcode can be computed according to coordinate relationships between the most prevalent colors and the least prevalent and/or absent colors in the derivative colorspace, including a maximal distance between the most prevalent colors and the least prevalent and/or absent colors. Additional or different colorspace conversion techniques can be used as discussed herein, and this is merely one example consistent with the present disclosure.
  • the barcode can be printed and/or embedded on a physical medium, e.g., a physical surface or material, using any suitable component, e.g., printing device 199 , with the least prevalent and/or absent colors, and the barcode can be scanned along the surface of the physical surface.
  • any suitable computer device including a computer, laptop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, where the barcode can be scanned along a surface of the computer display.
  • the logic flow 500 B may transmit the result of the scan to any suitable computer device 520 as discussed herein, including an indication as to whether or not the scan was of the barcode was successful, and any encoded information associated therewith was obtained.
  • FIG. 5C illustrates one embodiment of a logic flow 500 C.
  • the logic flow may be representative of some or all of the operations executed by one or more embodiments described herein.
  • the logic flow 500 C carries out one or more of the operations of flow 500 C, wherein one embodiment it carries out the operations of 502 , 504 , 506 , and 508 .
  • the logic flow 500 C may utilize the related colors to produce a scannable image 530 , such as a matrix, matrix barcode, fiducial marker, or any other suitable image for scanning, where the scannable image can, in addition to including non-black and non-white colors (such as the least prevalent and/or absent colors associated with a target, e.g. an environment), can include one or both of an ultraviolet layer and an infrared layer.
  • the matrix, matrix barcode, fiducial marker, or any other suitable image can be printed and/or embedded on a physical surface using any suitable component, e.g.
  • any suitable computer device including a computer, labtop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, the ultraviolet layer and/or the infrared layer, where the matrix, matrix barcode, fiducial marker, or any other suitable image can be scanned along a surface of the computer display.
  • the ultraviolet layer may be printed first along the physical surface and/or may form the top layer generated on a computer screen in order to maximize the benefits associated with ultraviolet light.
  • the colors of the scannable image need not be colors that have a relationship with the environment and/or not based on colorspace conversion techniques and can be any colors, including standard black and white colors, with a scannable image containing both an infrared and ultraviolet layer for detection.
  • FIG. 5D illustrates one embodiment of a logic flow 500 D.
  • the logic flow 500 D may be representative of some or all of the operations executed by one or more embodiments described herein.
  • the logic flow may detect a scannable image, e.g., a matrix, that includes one or more non-black and non-white colors, where each of the non-black and non-white colors are at least one of an i) an absent color in relation to an environment and/or ii) a least prevalent color associated with the environment, in addition to one or both of an ultraviolet layer and/or an infrared layer 540 .
  • the matrix is a barcode constructed with one or more colorspace conversion techniques as outlined herein, e.g., as discussed with respect to FIG. 5B , with the addition of an ultraviolet layer and/or infrared layer.
  • the scannable image can be scanned with any suitable component, e.g. a scanning device 197 , that has a suitable key, e.g. tristimulus equations associated with a conversion to an XYZ colorspace, that reveals the color-channels with associated colors that are associated with the scannable portions of the matrix barcode, including, in various embodiments, information encoded in the matrix barcode.
  • a suitable key e.g. tristimulus equations associated with a conversion to an XYZ colorspace
  • any suitable component e.g., scanning device 197
  • the barcode can include four or more distinct colors each associated with at least four distinct color-channels, where each of the colors are different from one another and different to the most prevalent colors of the environment, in addition to also having one or both the ultraviolet layer and/or the infrared layer, and as such, the scan can be a scan of six or more bits of information.
  • the barcode can be printed and/or embedded on a physical surface using any suitable component, e.g., printing device 199 , with the least prevalent and/or absent colors, and the barcode can be scanned along the surface of the physical surface.
  • any suitable computing device including a computer, labtop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, where the barcode can be scanned along a surface of the computer display.
  • the printing of the scannable image, e.g., barcode can be such that the topmost layer may be an ultraviolet layer and any associated scan may account for the ultraviolet layer first.
  • the scannable image is generated by a computer device and displayed by a computer display, the first layer displayed by the computer device can be the ultraviolet layer.
  • the logic flow 500 D may transmit the result of the scan to any suitable computer device 550 as discussed herein, including an indication as to whether or not the scan was of the barcode was successful, and any encoded information associated in addition to that was obtained.
  • FIG. 6A illustrates one technique 600 A of forming a scannable image in accordance with at least one embodiments of the present disclosure.
  • Scannable image layers 605 a, 610 a, and 615 a each represent a layer of a scannable image, such as a barcode, associated with one or more colors.
  • Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 a, 610 a, 615 a in order to produce layers 620 a, 625 a, and 630 a, and layers 620 a , 625 a, and 630 a may be consolidated into a single scannable image, e.g., barcode, 635 a .
  • the scannable layers 620 a, 625 a, and 630 a may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 635 a , wherein various embodiments one or more color-channels associated with colors of 620 a , 625 a, and 630 a may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors.
  • the scannable image 635 a can be printed on a physical surface of a target using any suitable device and/or generated by any suitable computing device for display on a computer display.
  • scannable image 635 a can be generated from scratch without converting from existing images, e.g., a target can be scanned, colorspaces associated therewith determined therefrom, and a final scannable image 635 a can be produced by performing one or more colorspace transformations on the colorspaces as disclosed herein or otherwise suitable.
  • FIG. 6B illustrates one technique 600 B of forming a scannable image in accordance with at least one embodiments of the present disclosure.
  • Scannable image layers 605 b, 610 b, and 615 b each represent a layer of a scannable image, such as a barcode, associated with one or more colors.
  • Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 b, 610 b, 615 b in order to produce layers 620 b, 625 b, and 630 b, and layers 620 b, 625 b, and 630 b may be consolidated into a single scannable image 635 b, e.g., barcode, 635 b.
  • the scannable layers 620 b, 625 b, and 630 b may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 635 b, wherein various embodiments one or more color-channels associated with colors of 620 b, 625 b, and 630 b may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors.
  • at least one layer e.g.
  • the ultraviolet or infrared layer 630 b can be made with ultraviolet or infrared ink or generated using ultraviolet or infrared light such that it contains an additional channel of information, e.g., an ultraviolet layer or infrared layer of information, which can absorb, reflect, project, and/or illuminate ultraviolet or infrared light, wherein various embodiments the ultraviolet layer or infrared layer 630 b may be the first layer of image 635 b.
  • the ultraviolet or infrared layer 630 b may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 635 b, and in various embodiments, only an ultraviolet channel may be associated with the ultraviolet layer 630 b.
  • the scannable image 635 b can be printed on a physical surface of a target using any suitable device and/or generated by any suitable computer device for display on a computer display.
  • the scannable image 635 b is a fiducial marker that takes advantage of the inherent orienting features of ultraviolet and/or infrared light when being scanned by a suitable device that can detect either one or both of ultraviolet and/or infrared light.
  • a suitable device e.g., scanning device 197
  • the spatial relationship of the object associated with the fiducial maker 635 b e.g.
  • an object with the fiducial marker labeled thereon and/or a computer display generating the fiducial marker 635 b, in relation to the scanning device 197 and other objects in an environment containing the device is easier to ascertain because of the inherent properties associated with the reflection and detection of ultraviolet and/or infrared light.
  • FIG. 6C illustrates one technique 600 C of forming a scannable image in accordance with at least one embodiments of the present disclosure.
  • Scannable image layers 605 c, 610 c, 615 c, and 620 c each represent a layer of a scannable image, such as a barcode, associated with one or more colors.
  • Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 c, 610 c, 615 c, and 620 c in order to produce layers 625 c, 630 c, 635 c and 640 c , and layers 625 c, 630 c, 635 c and 640 c may be consolidated into a single scannable image, e.g., barcode, 645 c.
  • the scannable layers 625 c, 630 c, 635 c and 640 c may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 645 c, where in various embodiments one or more color-channels associated with colors of 625 c, 630 c, 635 c and 640 c may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors.
  • At least one layer can be made with infrared ink or generated using infrared light such that it contains an additional channel of information, e.g., an ultraviolet layer of information, which can absorb, reflect, project, and/or illuminate infrared light, where in various embodiments the infrared layer 630 c may be the first layer of image 635 c.
  • the infrared layer 630 c may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 645 c , and in various embodiments, only an infrared channel may be associated with the infrared layer 630 d.
  • At least one layer can be made with ultraviolet ink or generated using ultraviolet light such that it contains an additional channel of information, e.g., an ultraviolet layer of information, which can absorb, reflect, project, and/or illuminate ultraviolet light, where in various embodiments the ultraviolet layer 640 c may be the first layer of image 645 c.
  • the ultraviolet layer 640 c may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 645 c, and in various embodiments, only an ultraviolet channel may be associated with the ultraviolet layer 640 c.
  • the scannable image 645 c is a fiducial marker that takes advantage of the inherent orienting features of ultraviolet and/or infrared light when being scanned by a suitable device that can detect either one or both of ultraviolet and/or infrared light.
  • a suitable device e.g., scanning device 197
  • the spatial relationship of the object associated with the fiducial maker 645 c e.g.
  • fiducial marker 645 c utilizes both ultraviolet and infrared light
  • the presence of both operates as a fail-safe if the functionality of the scanning device 197 is compromised, and/or if an initial scan fails to detect one or the other.
  • the scannable image 645 c may include both an infrared layer 635 c and an ultraviolet layer 640 c, where the printing or generating of layer 645 c may be such that the ultraviolet layer 640 c may be the first layer in order to take advantage of the characteristics associated with ultraviolet light.
  • layers 635 c and 640 c can include color-channel information, e.g., scannable colors that have a relationship with a target, in various embodiments, layers 635 c and 640 c can be associated strictly with infrared and/or ultraviolet information respectively.
  • the colors of layer 620 c, 625 c, and 630 c do not have to be layer that has a relationship with the target, and in various embodiments, said layers can be composed of black and white colors and/or other colors unrelated to the target and/or not based on colorspace conversion techniques.
  • FIG. 7 illustrates a computer or tablet system 700 for generating and scanning a scannable image 740 .
  • the tablet system includes a tablet 702 for generating a scannable image 740 , e.g., barcode, where the tablet 702 includes applications 705 A-E, application N, and application 420 , where one embodiment of application 420 is described in greater detail above with respect to FIG. 4 .
  • the tablet 702 may include one or more user interface devices 720 which a user can use to interface with the tablet 702 .
  • the tablet 702 can generate a scannable image 740 that includes one or both of an ultraviolet and infrared layer.
  • the tablet 702 can be configured to ensure that the top layer is an ultraviolet layer to take advantage of the properties inherent with ultraviolet light.
  • the image can further include one or more colors layer, including white and black layers.
  • the image can further include one or more non-black and non-white colors layers that are related to colors associated with the environment where the tablet is located, e.g., the tablet can be configured to have a camera with an application, e.g., 420 , that can scan an environment and produce a scannable image 740 with colors related to that environment.
  • the colors related to the environment can be colors based on one or more colorspace transformation techniques as discussed herein, including colors that are least prevalent and/or absent from the environment containing the tablet 702 and determined by one or more colorspace conversions.
  • the system 700 can further include a camera or scanning device c 750 that can scan the scannable image 740 , wherein various embodiments the camera or scanning device c 750 may include application 420 (as discussed above), and/or a colorspace key and/or infrared verification bit and/or ultraviolet verification bit as disclosed herein, and in order to perform a valid scan of scannable image 740 and/or obtain any encoded information associated therewith.
  • a camera or scanning device c 750 may include application 420 (as discussed above), and/or a colorspace key and/or infrared verification bit and/or ultraviolet verification bit as disclosed herein, and in order to perform a valid scan of scannable image 740 and/or obtain any encoded information associated therewith.
  • FIG. 8 illustrates an embodiment of a graphical user interface (GUI) 800 for an application of the system 100 .
  • GUI graphical user interface
  • the user interface 800 is configured for the application 420 of FIG. 4 .
  • the GUI 800 includes several components, such as a toolbar 802 and GUI elements.
  • the toolbar 802 includes, as one example tool, a recognize text tool 804 that, when invoked, scans an image 806 , e.g., a barcode generated from one or more colorspace techniques and/or containing one or both of an ultraviolet layer and/or infrared layer as outlined herein.
  • the scan can be using a key and/or verification bit in order for a valid scan to take place, where a proper scan may operate as a security measure to access and/or identify sensitive information 808 .
  • the appropriate colorspace transform mechanism provides the most accurate edge detection results because an underlying colorspace model has a higher likelihood at edge detection than any other applicable colorspace model, and the barcode can be generated with this in mind.
  • FIG. 9 illustrates an embodiment of an exemplary computing architecture 900 suitable for implementing various embodiments as previously described.
  • the computing architecture 900 may comprise or be implemented as part of an electronic device. Examples of an electronic device may include those described with reference to FIG. 3 , among others. The embodiments are not limited in this context.
  • a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer.
  • a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer.
  • an application running on a server and the server can be a component.
  • One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
  • the computing architecture 900 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth.
  • processors multi-core processors
  • co-processors memory units
  • chipsets controllers
  • peripherals interfaces
  • oscillators oscillators
  • timing devices video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth.
  • the embodiments are not limited to implementation by the computing architecture 900 .
  • the computing architecture 900 comprises a processing unit 904 , a system memory 906 and a system bus 908 .
  • the processing unit 904 can be any of various commercially available processors, including without limitation an AMD® Athlon®, Duron® and Opteron® processors; ARM® application, embedded and secure processors; IBM® and Motorola® DragonBall® and PowerPC® processors; IBM and Sony® Cell processors; Intel® Celeron®, Core (2) Duo®, Itanium®, Pentium®, Xeon®, and XScale® processors; and similar processors. Dual microprocessors, multi-core processors, and other multi-processor architectures may also be employed as the processing unit 904 .
  • the system bus 908 provides an interface for system components including, but not limited to, the system memory 906 to the processing unit 904 .
  • the system bus 908 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures.
  • Interface adapters may connect to the system bus 908 via a slot architecture.
  • Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
  • the computing architecture 900 may comprise or implement various articles of manufacture.
  • An article of manufacture may comprise a computer-readable storage medium to store logic.
  • Examples of a computer-readable storage medium may include any tangible media capable of storing electronic data, including volatile memory or non-volatile memory, removable or non-removable memory, erasable or non-erasable memory, writeable or re-writeable memory, and so forth.
  • Examples of logic may include executable computer program instructions implemented using any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, object-oriented code, visual code, and the like.
  • Embodiments may also be at least partly implemented as instructions contained in or on a non-transitory computer-readable medium, which may be read and executed by one or more processors to enable performance of the operations described herein.
  • the system memory 906 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory, polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information.
  • the system memory 906 can include non-volatile memory 910 and/or volatile memory 912
  • the computer 902 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 914 , a magnetic floppy disk drive (FDD) 916 to read from or write to a removable magnetic disk 918 , and an optical disk drive 920 to read from or write to a removable optical disk 922 (e.g., a CD-ROM or DVD).
  • the HDD 914 , FDD 916 and optical disk drive 920 can be connected to the system bus 908 by a HDD interface 924 , an FDD interface 926 and an optical drive interface 928 , respectively.
  • the HDD interface 924 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and IEEE 1394 interface technologies.
  • the drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth.
  • a number of program modules can be stored in the drives and memory units 910 , 912 , including an operating system 930 , one or more application programs 932 , other program modules 934 , and program data 936 .
  • the one or more application programs 932 , other program modules 934 , and program data 936 can include, for example, the various applications and/or components of the system 100 .
  • a user can enter commands and information into the computer 902 through one or more wire/wireless input devices, for example, a keyboard 938 and a pointing device, such as a mouse 940 .
  • Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like.
  • IR infra-red
  • RF radio-frequency
  • input devices are often connected to the processing unit 904 through an input device interface 942 that is coupled to the system bus 908 , but can be connected by other interfaces such as a parallel port, IEEE 1394 serial port, a game port, a USB port, an IR interface, and so forth.
  • a monitor 944 or other type of display device is also connected to the system bus 908 via an interface, such as a video adaptor 946 .
  • the monitor 944 may be internal or external to the computer 902 .
  • a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
  • the computer 902 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 948 .
  • the remote computer 948 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 902 , although, for purposes of brevity, only a memory/storage device 950 is illustrated.
  • the logical connections depicted include wire/wireless connectivity to a local area network (LAN) 952 and/or larger networks, for example, a wide area network (WAN) 954 .
  • LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
  • the computer 902 When used in a LAN networking environment, the computer 902 is connected to the LAN 952 through a wire and/or wireless communication network interface or adaptor 956 .
  • the adaptor 956 can facilitate wire and/or wireless communications to the LAN 952 , which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 956 .
  • the computer 902 can include a modem 958 , or is connected to a communications server on the WAN 954 , or has other means for establishing communications over the WAN 954 , such as by way of the Internet.
  • the modem 958 which can be internal or external and a wire and/or wireless device, connects to the system bus 908 via the input device interface 942 .
  • program modules depicted relative to the computer 902 can be stored in the remote memory/storage device 950 . It may be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
  • the computer 902 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.11 over-the-air modulation techniques).
  • wireless communication e.g., IEEE 802.11 over-the-air modulation techniques.
  • the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices.
  • Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity.
  • a Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
  • FIG. 10 illustrates a block diagram of an exemplary communications architecture 1000 suitable for implementing various embodiments as previously described.
  • the communications architecture 1000 includes various common communications elements, such as a transmitter, receiver, transceiver, radio, network interface, baseband processor, antenna, amplifiers, filters, power supplies, and so forth.
  • the embodiments are not limited to implementation by the communications architecture 1000 .
  • the communications architecture 1000 comprises includes one or more clients 1002 and servers 1004 .
  • the clients 1002 may implement the client device 310 .
  • the servers 1004 may implement the server device 950 .
  • the clients 1002 and the servers 1004 are operatively connected to one or more respective client data stores 1008 and server data stores 1010 that can be employed to store information local to the respective clients 1002 and servers 1004 , such as cookies and/or associated contextual information.
  • the clients 1002 and the servers 1004 may communicate information between each other using a communication framework 1006 .
  • the communications framework 1006 may implement any well-known communications techniques and protocols.
  • the communications framework 1006 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
  • the communications framework 1006 may implement various network interfaces arranged to accept, communicate, and connect to a communications network.
  • a network interface may be regarded as a specialized form of an input output interface.
  • Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1000 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like.
  • multiple network interfaces may be used to engage with various communications network types. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks.
  • a communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
  • a private network e.g., an enterprise intranet
  • a public network e.g., the Internet
  • PAN Personal Area Network
  • LAN Local Area Network
  • MAN Metropolitan Area Network
  • OMNI Operating Missions as Nodes on the Internet
  • WAN Wide Area Network
  • wireless network a cellular network, and other communications networks.
  • Some embodiments may be described using the expression “one embodiment” or “an embodiment” along with their derivatives. These terms mean that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment. Further, some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. These terms are not necessarily intended as synonyms for each other. For example, some embodiments may be described using the terms “connected” and/or “coupled” to indicate that two or more elements are in direct physical or electrical contact with each other. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Multimedia (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Signal Processing (AREA)
  • Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • Artificial Intelligence (AREA)
  • General Health & Medical Sciences (AREA)
  • Electromagnetism (AREA)
  • Image Processing (AREA)
  • Image Analysis (AREA)
  • Color Image Communication Systems (AREA)
  • Optical Filters (AREA)
  • Devices For Indicating Variable Information By Combining Individual Elements (AREA)
  • Details Of Garments (AREA)
  • Outer Garments And Coats (AREA)
  • Facsimile Image Signal Circuits (AREA)

Abstract

Techniques to improve detection and security of images, including formation and detection of matrix-based images. Some techniques include detecting a matrix-based image that is optimized for detection in a particular environment. The matrix-based image may be a matrix bar code. The matrix bar code may include a plurality of non-black and non-white colors, where each one of the plurality of non-black and non-white colors are at least one of an absent color in relation to the environment and a least prevalent color associated with the environment.

Description

    RELATED APPLICATION
  • This application is a division of U.S. patent application Ser. No. 16/357,231, titled “OPTIMIZING DETECTION OF IMAGES IN RELATION TO TARGETS BASED ON COLORSPACE TRANSFORMATION TECHNIQUES” filed on Mar. 18, 2019. The contents of the aforementioned application are incorporated herein by reference.
  • BACKGROUND
  • Since time immemorial, certain materials (e.g., paint, ink, and/or the like) have been used to memorialize scenes and/or objects into semi-permanent to permanent mediums. Such memorialization includes efforts in photography to create photos. Computer technologies allow for digitization and detections of these photos into images and have introduced image processing as a technical field. Edge detection constitutes at least one aspect of image processing and has applications in a number of cases.
  • It is with respect to these and other considerations that the present improvements have been needed.
  • SUMMARY
  • The following presents a simplified summary in order to provide a basic understanding of some novel embodiments described herein. This summary is not an extensive overview, and it is not intended to identify key/critical elements or to delineate the scope thereof. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is presented later.
  • One aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment. The apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: receive a representative dataset containing at least one of i) one or more images of a target and ii) one or more videos of the target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors, where the matrix is associated with the target.
  • Another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment. The method includes: detecting a matrix on display via a physical medium and associated with an environment, where the matrix includes a plurality of non-black and non-white colors, where each one of the plurality of non-black and non-white colors are at least one of i) an absent color in relation to the environment and ii) a least prevalent color associated with the environment.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment. The article of manufacture includes: a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors, where the matrix barcode is embedded with computer data, where the computer data is represented by a plurality of pixels associated with non-black and non-white colors, and where the plurality of pixels are associated with at least 3 color-channels forming the matrix barcode.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an ultraviolet layer. The apparatus includes: receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors and at least one ultraviolet layer, where the matrix is associated with the target.
  • Yet another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment, where the matrix is part of an image that includes at least one ultraviolet layer. The method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors and at least one ultraviolet layer, where the at least one ultraviolet layer reflects ultraviolet light, and where the matrix barcode includes four or more bits of information.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment, where the matrix barcode is part of an image with an ultraviolet layer. The article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating ultraviolet light, where the matrix barcode includes a combination of four or more constituent matrix barcodes each associated with a distinct color-channel, including an ultraviolet color-channel associated with at least one layer of at least one of the four constituent matrix barcodes.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an infrared layer. The apparatus includes: receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, and create a matrix using the related plurality of colors and at least one infrared layer, where the matrix is associated with the target.
  • Yet another aspect of the present disclosure includes a method for detecting a matrix optimized for detection in a particular environment, where the matrix is part of an image that includes at least one infrared layer. The method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors and at least one infrared layer, where the at least one infrared layer reflects infrared light, and where the matrix barcode includes four or more bits of information.
  • Yet another aspect of the present disclosure includes an article of manufacture that displays a matrix barcode optimized for detection in a particular environment, where the matrix barcode is part of an image with an infrared layer. The article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating infrared light, where the matrix barcode includes a combination of four or more constituent matrix barcodes each associated with a distinct color-channel, including an infrared color-channel associated with at least one layer of at least one of the four constituent matrix barcodes.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix barcode that contains both an ultraviolet layer and an infrared layer. The apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: create a matrix barcode using at least one infrared layer and at least one ultraviolet layer.
  • Yet another aspect of the present disclosure includes an apparatus for creating a matrix optimized for detection in a particular environment, where the matrix is part of a layered image that includes an infrared layer and an ultraviolet layer. The apparatus includes: a memory to store instructions, and processing circuitry, coupled with the memory, operable to execute the instructions, that when executed, cause the processing circuitry to: create a matrix barcode using one or more color layers, at least one infrared layer and at least one ultraviolet layer, receive a representative dataset containing at least one of i) one or more images and ii) one or more videos of a target, the target including at least one of i) an environment, ii) a live entity and iii) an object, process the representative dataset to create a histogram of the target, identify a most prevalent plurality of colors associated with the target based on the histogram, and determine a related plurality of colors based on the histogram, where the related plurality of colors include at least one of i) an absent color in relation to the target and ii) a least prevalent color associated with the target, where the related plurality of colors are included in each one of the one or more color layers.
  • Yet another aspect of the present disclosure includes a method for detecting a matrix barcode optimized for detection in a particular environment, where the matrix barcode includes both an ultraviolet layer and an infrared layer. The method includes: detecting a matrix barcode on display via a physical medium and associated with an environment, where the matrix barcode includes a plurality of non-black and non-white colors, at least one infrared layer, and at least one ultraviolet layer, and where the at least one ultraviolet layer reflects ultraviolet light, and where the at least one infrared layer reflects infrared light.
  • Yet another aspect of the present disclosure includes an article of manufacture for displaying a matrix barcode with both an ultraviolet layer and an infrared layer. The article of manufacture includes: a matrix barcode on display via a suitable surface for at least one of: projecting, absorbing, reflecting, or illuminating both infrared light and ultraviolet light, the matrix barcode including at least one infrared layer and at least one ultraviolet layer.
  • Yet another aspect of the present disclosure includes an article of manufacture for displaying a matrix barcode with both an ultraviolet layer and an infrared layer, and one or more colored layers optimized for detection in a particular environment. The article of manufacture includes: a matrix barcode on display via a suitable surface reflecting both infrared light and ultraviolet light, the matrix barcode including at least one infrared layer, at least one ultraviolet layer, and a plurality of non-black and non-white colors, and where the plurality of non-black and non-white colors are associated with at least three non-white and non-black color-channels.
  • To the accomplishment of the foregoing and related ends, certain illustrative aspects are described herein in connection with the following description and the annexed drawings. These aspects are indicative of the various ways in which the principles disclosed herein can be practiced and all aspects and equivalents thereof are intended to be within the scope of the claimed subject matter. Other advantages and novel features may become apparent from the following detailed description when considered in conjunction with the drawings.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates an embodiment of a system to improve edge detection in images in accordance with at least one embodiment of the present disclosure.
  • FIG. 2A illustrates an embodiment of a clustering process for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 2B illustrates an embodiment of a colorspace conversion technique for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 3 illustrates an embodiment of a centralized system for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 4 illustrates an embodiment of an operating environment for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5A illustrates an embodiment of a first logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5B illustrates an embodiment of a second logic flow for the system of FIG. 1 and in accordance with at least one embodiment of the present disclosure.
  • FIG. 5C illustrates an embodiment of a third logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 5D illustrates an embodiment of a fourth logic flow for the system of FIG. 1 in accordance with at least one embodiment of the present disclosure.
  • FIG. 6A illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 6B illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 6C illustrates formation of a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 7 illustrates a computer device for generating and scanning a scannable image in accordance with at least one embodiment of the present disclosure.
  • FIG. 8 illustrates an embodiment of a graphical user interface (GUI) for the system of FIG. 1.
  • FIG. 9 illustrates an embodiment of a computing architecture.
  • FIG. 10 illustrates an embodiment of a communications architecture.
  • DETAILED DESCRIPTION
  • Various embodiments are directed to improving image processing by identifying which colorspace model is most appropriate to use for detection in a particular environment, e.g., to convert between colorspace(s) to improve detection within particular environments or in association with particular targets. In various embodiments, the conversion between colorspace(s) provides for a matrix located on an object or displayed by an electronic device, where the matrix is optimized for detection in an environment by performing one or more colorspace conversations in generating the matrix. In one or more embodiments, the matrix is a matrix barcode, and in one or more embodiments, the matrix barcode is a fiducial marker.
  • In various embodiments, the colorspace conversion encodes information with respect to a matrix barcode, which permits proper scanning of the object associated with the matrix barcode, while preventing tampering and false verifications, e.g., the color-channels containing the information are tied to the conversion, and without having a scanning device accessing information related to the conversion, the scan cannot verify the object associated with the object and/or access any information associated therewith.
  • In various embodiments, a colorspace conversion provides for increasing the amount of information stored on the matrix, e.g., matrix barcode, as the color-channels associated with the converted-to (derivative) colorspace can be increased as needed, without any limitation (provided the scanning equipment is suitably configured to make detections when the matrix is scanned).
  • In various embodiments, to further increase the information associated with the matrix, add additional layers of security, and/or make optimal use of inks associated with printing the matrix, ultraviolet and/or infrared layers can be used with respect to the matrix.
  • Accordingly, various embodiments of the present disclosure provide at least one of the following advantages: i) enhancing detection of an image, e.g., matrix, on an object in an environment, (as the matrix colors are selected and optimized with the colors of the environment in mind), ii) providing for a more secure verification, and iii) storing more information on the matrix, as there are no front-loaded limitations on how many color-channels can be employed, and the amount of information can be further increased, and a verification scan made more secure, by adding infrared or ultraviolet features.
  • In various embodiments, the colorspace conversions improve edge detection. In image processing, edge detection is a known technical field and techniques for edge detection provide different results for different colorspace models. It is not unusual for one colorspace model to provide better results over another colorspace in edge detection because having image data in accordance with the colorspace model has a higher likelihood of success in edge detection than the other colorspace model.
  • Colorspace models are configured to represent color data, but most models differ in their representation of that color data. For instance, the CIELAB or LAB colorspace model represents color as three values: L for the Luminance/Lightness and Alpha (A) and Beta (B) for the green-red and blue-yellow color components, respectively. The LAB colorspace model is typically used when converting from a Red-Green-Blue (RGB) colorspace model into Cyan-Magenta-Yellow-Black (CMYK). For some images, representing its color data in the LAB colorspace model provides better edge detection results than other colorspace models including the RGB model. As a result, the embodiments can improve affordability, scalability, modularity, extendibility, or interoperability for an operator, device or network that utilizes image detection as a means of verifying a transaction by providing a more effective and accurate manner of scanning an image associated with the verification (and by extension, minimizing redundant consumption of computer resources).
  • With general reference to notations and nomenclature used herein, the detailed descriptions which follow may be presented in terms of program procedures executed on a computer or network of computers. These procedural descriptions and representations are used by those skilled in the art to most effectively convey the substance of their work to others skilled in the art.
  • A procedure is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. These operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic or optical signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It proves convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be noted, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to those quantities.
  • Further, the manipulations performed are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. No such capability of a human operator is necessary, or desirable in most cases, in any of the operations described herein which form part of one or more embodiments. Rather, the operations are machine operations. Useful machines for performing operations of various embodiments include general purpose digital computers or similar devices.
  • Various embodiments also relate to apparatus or systems for performing these operations. This apparatus may be specially constructed for the required purpose or it may comprise a general purpose computer as selectively activated or reconfigured by a computer program stored in the computer. The procedures presented herein are not inherently related to a particular computer or other apparatus. Various general purpose machines may be used with programs written in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these machines may appear from the description given.
  • Reference is now made to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding thereof. It may be evident, however, that the novel embodiments can be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form to facilitate a description thereof. The intention is to cover all modifications, equivalents, and alternatives consistent with the claimed subject matter.
  • FIG. 1 illustrates a block diagram for a system 100. Although the system 100 shown in FIG. 1 has a limited number of elements in a certain topology; it may be appreciated that the system 100 may include more or fewer elements in alternate topologies as desired for a given implementation. The system 100 may implement some or all of the structure and/or operations for the system 100 in a single computing entity, such as entirely within a single device.
  • The system 100 may comprise an apparatus 120. The apparatus 120 may be generally arranged to process input 110 using various components and generate output 130 of which (some) output 130 is displayed on a display device or printed on a suitable material surface. The apparatus 120 may comprise a processor 140 (e.g., processing circuit) and computer memory 150. The processing circuit 140 may be any type of logic circuit and the computer memory 150 may be a configuration of one or more memory units.
  • The apparatus 120 further includes logic 160 stored in the computer memory 150 and executed on the processing circuit 140. The logic 160 is operative to cause the processing circuit 140 to process image data of image datasets 170 into patched image data where the image data is being configured in accordance with a colorspace model. The colorspace model as described herein refers to any suitable colorspace model, such as Red-Green-Blue (RGB), Cyan-Magenta-Yellow-Black (CMYK), Luminance-Alpha-Beta (LAB), and/or the like. For example, the Alpha and Beta channels of the LAB colorspace model refer to green-red and blue-yellow color components, respectively. The green-red component may represent a variance between red and green with green in the negative direction, and red in the positive direction along an axis and the blue-yellow component may represent a variance between blue and yellow with blue in the negative direction and yellow in the positive direction along an axis. In various embodiments, an edge may be defined (mathematically) as each pixel location where the Alpha channel has a value of zero (0) or near zero.
  • In various embodiments, the patched image data includes a plurality of patches of which each patch comprises color data (e.g., pixel data where each pixel is represented as a tuple of Red-Green-Blue (RGB) color intensities). As described herein, one colorspace model (e.g., RGB) may correspond to a higher likelihood of success in edge detection than another colorspace model. Some images provide optimal or near-optimal edge detection results when arranged in RGB while other images provide optimal or near-optimal edge detection results when arranged in LAB or an XYZ colorspace and vice versa.
  • In various embodiments, the logic 160 is further operative to cause the processing circuit 140 to apply the colorspace transform mechanism 180 to the image data to generate the transformed image data in accordance with the other colorspace model. Then, the logic 160 is operative to cause the processing circuit 140 to apply an edge detection technique 190 to the transformed image data. The edge detection technique 190 is an image processing technique that refers to any one of a number of algorithms for identifying edges or boundaries of objects within images. In general, the edge detection technique 190 provides information (e.g., pixel data) indicating positions of edges in the image data of the image datasets 170. Some implementations of the edge detection technique 190 operate by detecting discontinuities in brightness and, for those implementations, having the image data in a LAB colorspace, or XYZ colorspace over RGB provides more precise edge detection results. Some implementations of the edge detection technique 190 provide accurate edge detection results when the image data is modeled according to HCL (Hue-Chroma-Luminance) instead of RGB.
  • In various embodiments, the logic 160 is further operative to cause the processing circuit 140 to identify an image group corresponding to the patched image data. The image datasets 170 further includes image group model data correlating images with a colorspace model most likely to provide appropriate edge detection results. In various embodiments, the image group model data indicates which colorspace model to use in transforming a given image prior to edge detection to achieve near-optimal edge detection results. The logic 160 is further configured to cause the processing circuit 140 to select a colorspace transform mechanism 180 based upon the image group. The colorspace transform mechanism 180 is operative to transform the image data into transformed image data in accordance with another colorspace model, the other colorspace model having a higher likelihood than the colorspace model at edge detection for the image group. It is appreciated that the other colorspace model may be any colorspace model including those with a different number of channels than the colorspace model.
  • In various embodiments, the logic 160 can be further operative to cause the processing circuit 140 to determine a colorspace that is optimal for detection in association with a particular object, entity, or environment, where a colorspace or histogram representation of the particular object, entity or environment can be part of the image datasets 170. The logic 160 can be further operative to cause the processing circuit 140 to determine the optimal colorspace based on one or more colorspace conversion operations, where the colorspace conversion operations can provide a mechanism for encoding information in any suitable medium, including but not limited to a matrix, such as a matrix barcode, a fiducial marker, any other suitable barcode, or any other suitable image. The logic 160 can be further operative to cause the processing circuit 140 to generate a scheme for a matrix, e.g., a matrix barcode, fiducial marker, etc. based on the colorspace determination and for detection in relation to the particular object, entity, or environment. The logic 160 can further be operative to cause the processing circuit 140 to provide for a scheme to add at least one ultraviolet layer and infrared layer to an image, such as a matrix or matrix barcode, useful for detection in relation to the particular object, entity, or environment, where the ultraviolet layer and/or infrared layer add additional data carrying capacity and/or security to the detectable image.
  • The one or more colorspace models as described herein, as stated and implied elsewhere herein, refers to any suitable colorspace model, such as colorspace employing a tristimulus system or scheme, the Red-Green-Blue (RGB), the Luminance-Alpha-Beta (LAB), an XYZ colorspace, and/or the like and/or variations of the same. Similarly, although various embodiments may refer to a particular conversion from one specific colorspace to another specific colorspace, conversions between other color spaces are contemplated and consistent with the teachings of the present disclosure.
  • In various embodiments, as described herein, one colorspace model (e.g., RGB or XYZ) may correspond to a higher likelihood of success in edge detection than another colorspace model in terms of detection of a displayed or printed image, e.g. barcode, in relation to an object, entity, or environment with a particular color distribution. Moreover, particular colors and color-channels associated with a colorspace may offer superior edge detection in relation to the object, entity, or environment. Some images provide optimal or near-optimal edge detection results when arranged in RGB while other images provide optimal or near-optimal edge detection results when arranged in XYZ or LAB and vice versa. By way of example, an image depicting a red balloon on a green field would appear much different in RGB than in LAB; therefore, with respect to edge detection, LAB would provide a higher likelihood than RGB at successfully identifying and locating edges (e.g., boundaries) of the red balloon, or a matrix, e.g., barcode or fiducial marker, that had a red color in the green environment.
  • In various embodiments, a color-channel is a distribution of colors with a first color and second color of first and second highest prevalence, respectively, where the first color becomes a minimum in the color channel and the second color becomes the maximum such that the boundary may be a transition between these colors. This boundary may be at least one pixel where the color changed from the first to the second color or vice versa. If the first color is set to zero (0) and the second color is set to two hundred and fifty-five (255), then, mathematically, this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255. In various embodiments, color-channels, e.g., “R,” “G,” and “B” define a colorspace such as RGB (e.g., a first colorspace based on a tristimulus system), and in various embodiments custom color-channels can be created using a (second) tristimulus system associated with and defining an XYZ colorspace (and/or conversions to an XYZ colorspace). In various embodiments, the color-channels can be greater than three.
  • In various embodiments, as discussed herein, one or more color-channel ranges are selected such that a maximum color value of one or more color channel corresponds to a unique color value, most prevalent color value, and/or highest color value of a target object, entity, and/or environment associated with a scan and the minimum color value of the color-channel corresponds to a most unique color, most prevalent color value and/or highest color value of the scannable image, e.g. matrix, matrix barcode, and/or fiducial marker, where additionally, the most prevalent value and/or highest color value of the scannable image is also a least prevalent (lowest color value) and/or absent from the target object, entity, and/or environment associated with the scan, or visa-versa (e.g. with respect to the maximum or minimum values).
  • In various embodiments, as described herein, particular objects, entities, or environments may have color distributions that make more complicated and varied colorspaces, and colors and color-channels associated therewith, including colors imperceptible by the human eye, more attractive for detection, in addition to increasing capacity for storage and encryption of information. As such, in various embodiments, the logic 160 is further operative to cause the processing circuit 140 to identify an image group corresponding to the patched image data. The image datasets 170 further includes image group model data correlating images with a colorspace transform model most likely to provide appropriate edge detection results. In some embodiments, the image group model data indicates which colorspace transform model to use in transforming a given image prior to edge detection in order to achieve near-optimal edge detection results. The logic 160 is further configured to cause the processing circuit 140 to select a colorspace transform mechanism 180 based upon the image group. The colorspace transform mechanism 180 is operative to transform the image data into transformed image data in accordance with another colorspace model, the other colorspace model having a higher likelihood than the colorspace model at edge detection for the image group.
  • In various embodiments, the system 100 can include one or more of a camera or video device 195 and/or a scanning device 197, where both device 195 and device 197 can be any suitable device for obtaining, capturing, editing, and/or scanning images, including but not limited to video or camera pictures, of objects, entities, and/or environments. The logic 160 can be configured to capture or scan images of a particular object, entity or environment using device 195 and/or device 197, where the captured images can become part of image datasets 170 and used for determining suitable colorspaces, performing colorspace conversions, and/or scanning images determined from colorspace conversions, as may be consistent with the teachings provided herein.
  • In various embodiments, the system 100 can include a printing device 199 (e.g. printer) or an application for the same, where images part of image datasets 170 and/or images generated by one or more components of system 100, by applying a colorspace transformation technique or mechanism, such as a scannable matrix, matrix barcode, or fiducial marker can be printed by printing device 199 and/or printing device 199 can provide a scheme for another device to print or generate an image in association with the scannable matrix, matrix barcode, or fiducial marker.
  • FIG. 2A illustrates an embodiment of a clustering process 200A for the system 100. The clustering process 200A operates on image datasets (e.g., the image datasets 170 of FIG. 1) storing color data for images.
  • In some embodiments of the clustering process 200A, color data 202 of an image undergoes a patching operation where the image is processed into a plurality of patches 204 of patched image data 206. Each patch 204 of the patched image data 206 includes color data in accordance with a colorspace model, such as pixel data having RGB tuples. The clustering process 200A further processes the patched image data 206, via a transformation operation 208, by applying a colorspace transform mechanism on the color data of the patched image 206 to transform patched image data into transformed image data of a transformed image 210. The color data of the patched image 206 is configured in accordance with the colorspace model and new color data for the transformed image 210 is generated according to another colorspace model.
  • In some embodiments, the clustering process 200A performs a mini-colorspace transform for at least one patch of the patched image 206, possibly leaving one or more patches without a transformation. Via the transformation operation 208, the mini-colorspace transform modifies the color data in the at least one patch to transform patched image data into transformed image data of a transformed image 210. The clustering process 200A may perform stitching between patches to make the patched image 206 uniform as opposed to creating artificial edges.
  • FIG. 2B illustrates an example of a colorspace conversion scheme 200B in accordance with various embodiments of the present disclosure. A histogram 218 representation of a particular object, entity, or environment 215 is provided (where the numbers 100, 90, 80, and 70 are intended to represent a simplified version of colors distribution values of one or more colors representing the particular object, entity, or environment 215). The histogram 218 can be generated by having one or more components of system 100 performing a scan of the particular object, entity, or environment 215 and generating a histogram 218 of the most prevalent colors, least prevalent colors, or absent colors of the object, entity, or environment 215. In one or more embodiments, the histogram 218 can be of four or more colors of the most prevalent colors of the object, entity, or environment. Since various embodiments of the present disclosure expressly contemplate using colors imperceptible to the human eye, there is no limitation on the number of colors that can be used with respect to the histogram 218, the colorspace conversions discussed herein, or any images generated from the colorspace conversions, including but not limited to a matrix, matrix barcode, fiducial marker, etc. can have in excess of four colors and four color-channels, where the four colors and/or four color-channels are distinct and different with respect to one another.
  • In various embodiments, one or more components of system 100 can determine the most prevalent colors associated with the object, entity, or environment 215, and the resulting histogram 218 may be based on that determination. The histogram 218 can be used to map the most prevalent colors to a distribution 222 associated with a suitable colorspace 224, including but not limited to an RGB colorspace 224. In various embodiments, the colors of histogram 218 are mapped pursuant to the tristimulus values of the RGB colorspace, e.g., “R,” “G,” and “B.” Any suitable mathematical conversion, e.g., linear-algebraic, etc. can be used to map the conversion to the RGB colorspace, e.g., convert the mapped RGB colorspace to another colorspace.
  • In various embodiments, once the distribution 222 is mapped according to the RGB colorspace 224, one or more components of system 100 can convert the RGB distribution 222 to a new colorspace 226 with a distribution 228 pursuant to the new colorspace 226. Any suitable colorspace conversion can be used, including converting to an XYZ colorspace, where the conversion can be pursuant to any suitable mathematical conversions and equations that govern the XYZ colorspace, including suitable tristimulus conversions between RGB and XYZ. In various embodiments, “Y” represents a luminance value of the XYZ space and at least one of “X” and “Z” (or both) represent a chrominance value of the colorspace and an associated distribution, e.g. 226 plotted pursuant to the XYZ colorspace.
  • In various embodiments, the luminance channel “Y” is filtered out resulting in colorspace 228′ and distribution 226′, which can assist in making determinations solely on actual chromatic values associated with the entity, object, or environment 215, without considering luminance (this is helpful at least because colors can be used that are imperceptible to the human eye). In various embodiments, four (or more) lines can be defined by points (a1, b1), (a2, b2), (a3, b3), and (a4, b4), and are selected to have a maximum distance apart with respect to distribution 226′. In various embodiments, the points a1, a2, a3, and a4 are selected to correspond to the most prevalent colors associated with entity, object, or environment 215 and b1, b2, b3, and b4 by extension, being opposite to those colors, may represent the least prevalent or absent colors in association with an entity, object, or environment b1, b2, b3, b4. These lines may define vectors for a new colorspace conversion in an XYZ or other suitable colorspace 245 and may form the basis for new XYZ tristimulus values. An image, such as a matrix or matrix barcode, can be made using colors associated with the new colorspace 250 and a distribution 245 of colors defined by color-channel vectors (i,−i), (j, −j), (k, −k), an additional color-channel and all other color-channels (omitted from display due to the limitations of three-dimensional space) associated therewith. In various embodiments, since the colors may correspond to less prevalent or absent colors in relation to where a potential scan may occur (or what is being scanned), e.g., a matrix barcode on an entity or object and/or in an environment with colors that have a maximum difference in relation thereto, edge detection is enhanced.
  • Alternatively, although not expressly shown, the maximum distance from the most prevalent colors to least prevalent colors can be determined, e.g., a1 to b1, a2 to b2, etc., and then lines can be drawn from b1, b2, b3, and b4 in a direction tangential, parallel or opposite a vector or direction associated with a1, a2, a3, and a4. The color-channel vectors (i,−i), (j, −j), (k, −k), an additional color-channel and all other color-channels (omitted from display due to the limitations of three-dimensional space) associated with colorspace 250 may be entirely colors absent and/or mildly prevalent in relation to entity, object, or environment 215, which can further enhance edge detection.
  • In various embodiments, when performing the colorspace conversion between 228′ and 250, in addition to carrying out the algebraic or other suitable conversions associated with the XYZ colorspace, the color-channel vectors, e.g. (i, −i), (j, −j), (k, −k), may be orthogonal to one another by performing any suitable mathematical and/or orientation operation on the vectors and/or by selecting suitable points on colorspace 226′ and distribution 228′ when making the conversion. In various embodiments, a second maximum difference between one or more points can be taken in space 250, in addition to an orientation operation to center the distribution 245 along the axis of the newly defined color-channel vectors, e.g. (i, −i), (j, −j), (k, −k), such that the color-channel vectors are orthogonal and have a maximum distance in relation to one another. In various embodiments, performing at least one of the orthogonality operation, maximum determination, and/or orienting operation can further enhance edge detection of an image generated for scanning, such as a matrix barcode, in relation to an entity, object, or environment 215 to be scanned.
  • In various embodiments, the various color-channels described above, including each vector, e.g. (−i, i), defines a first color that is a minimum in the color channel and the second color becomes the maximum. This boundary may be at least one pixel where the color changed from the first to the second color or vice versa. If the first color is set to zero (0) and the second color is set to two hundred and fifty-five (255), then, mathematically, this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255. In various embodiments, the boundary is such it may be a transition between these colors where, as discussed above, one or more color-channel ranges are selected such that a maximum color value of one or more color channel corresponds to a unique color value, most prevalent color value, and/or highest color value of a target object, entity, and/or environment associated with a scan and the minimum color value of the color-channel corresponds to a most unique color, most prevalent color value and/or highest color value of the scannable image, e.g. matrix, matrix barcode, and/or fiducial marker, where additionally, the most prevalent value and/or highest color value of the scannable image is also a least prevalent (lowest color value) and/or absent from the target object, entity, and/or environment associated with the scan, or visa-versa (e.g. with respect to the maximum or minimum values).
  • The length of the color-channel can be adjusted accordingly based on the capabilities of the scanning and image-acquiring abilities of the various components, e.g. camera or video device 195, scanning device 197, and/or recognition component 422-4 (discussed below with respect to FIG. 4), where the length increases the number of different colors between the minimum and maximum point of the color channel.
  • In various embodiments, the conversions between the RGB colorspace to the XYZ colorspace and/or a first converted-to (derivative) XYZ space to another XYZ colorspace can be governed by the tristimulus equations (Equation 1) that define the converted colorspace and a distribution of colorspace, where the value of x+y=z can be normalized to 1.

  • x=X/(X+Y+Z),

  • y=Y/(X+Y+Z),

  • z=Z/(X+Y+Z).  Equation 1
  • In various embodiments, the value of “X,” “Y,” and “Z,” is dependent on the input colors from the RGB colorspace (or in the case of a second conversion, from the converting colorspace). Although the tristimulus values are three be definition, as noted above, the conversion can involve more than three color-channels, including color-channels that define colors imperceptible to the human eye. In various embodiments, the conversion governed by Equation. 1 can form a key for a scanning device to scan an image defined by the conversion, such as a matrix, e.g., matrix barcode or fiducial marker. In various embodiments, this means that in addition to providing a vehicle for increasing the numbers of color-channels and colors for an image to be scanned, which means increasing bits of information that can be encoded therein, another benefit of various embodiments is offering a manner to securely encode information, e.g. without knowing the equation or equations of what colorspace govern and without knowing the input values (which are based on the first colorspace associated with the entity, object, or environment 215), a successful scan cannot occur. Accordingly, in various embodiments, the logic 160 of system 100 can cause a processor 140 (or an application programmed to carried out the operations of 100) to provide a scanning device 197 with a key governed by Equation 1 in order to scan an image that is encoded pursuant to one or more colorspace conversions associated with Equation 1.
  • In various embodiments, the logic 160 of system 100 can cause a processor 140 to provide a scheme for adding either one or both of an ultraviolet layer and/or an infrared layer to an image, such as a matrix, e.g. matrix barcode or fiducial marker, where the image contains more than one non-black or non-white colors governed by any suitable colorspace. In various embodiments, the scheme may include both an ultraviolet layer and an infrared layer, where the ultraviolet layer may form the first layer of an image in order to take advantage of its properties. In various embodiments, the non-black and non-white colors of the scannable image may be determined by one or more colorspace conversion techniques as outlined herein. In various embodiments, Non-black and non-white colors means colors that are not black or white. In various embodiments, non-black and non-white colors means colors that are not black, white or based on a greyscale distribution.
  • FIG. 3 illustrates a block diagram of a distributed system 300. The distributed system 300 may distribute portions of the structure and/or operations for the system 100 across multiple computing entities. Examples of distributed system 300 may include without limitation a client-server architecture, a 3-tier architecture, an N-tier architecture, a tightly-coupled or clustered architecture, a peer-to-peer architecture, a master-slave architecture, a shared database architecture, and other types of distributed systems. The embodiments are not limited in this context.
  • The distributed system 300 may comprise a client device 310 and a server device 320. In general, the client device 310 and/or the server device 320 may be the same or similar to the apparatus 120 as described with reference to FIG. 1. For instance, the client device 310 and the server device 320 may each comprise a processing component 330 which is the same or similar to the processing circuit 140 as described with reference to FIG. 1. In another example, the devices 310, 320 may communicate over a communications media 312 using communications signals 314 via a communications component 340.
  • The server device 320 may communicate with other devices over the communications media 312, using communications signals 314, via the communications component 340. The other devices may be internal or external to the device 320 as desired for a given implementation.
  • The client device 310 may comprise or employ one or more client programs that operate to perform various methodologies in accordance with the described embodiments. In one embodiment, for example, the client device 310 may implement the system 100 including the logic 160 of FIG. 1, where in various embodiments, the client device 310 can implement one or more operations to form an image based on one or more colorspace conversions as outlined above and herein.
  • The server device 320 may comprise or employ one or more server programs that operate to perform various methodologies in accordance with the described embodiments. In one embodiment, for example, the server device 320 may implement the clustering process 200A of FIG. 2A and generate image group model data 350 and/or generate image group model data 350 by performing one or more of the colorspace conversion operations of scheme 200B. The image group model data 350 can include a printing scheme or color distribution for an image to be scanned in an entity, object, or environment 215, such as a matrix, e.g., matrix barcode or fiducial marker.
  • The devices 310,320 may comprise any electronic device capable of receiving, processing, and sending information for the system 100. Examples of an electronic device may include without limitation an ultra-mobile device, a mobile device, a personal digital assistant (PDA), a mobile computing device, a smart phone, a telephone, a digital telephone, a cellular telephone, ebook readers, a handset, a one-way pager, a two-way pager, a messaging device, a computer, a personal computer (PC), a desktop computer, a laptop computer, a notebook computer, a netbook computer, a handheld computer, a tablet computer, a server, a server array or server farm, a web server, a network server, an Internet server, a work station, a mini-computer, a main frame computer, a supercomputer, a network appliance, a web appliance, a distributed computing system, multiprocessor systems, processor-based systems, consumer electronics, programmable consumer electronics, game devices, television, digital television, set top box, wireless access point, base station, subscriber station, mobile subscriber center, radio network controller, router, hub, gateway, bridge, switch, machine, or combination thereof. The embodiments are not limited in this context.
  • The devices 310, 320 may execute instructions, processing operations, or logic for the system 100 using the processing component 330. The processing component 330 may comprise various hardware elements, software elements, or a combination of both. Examples of hardware elements may include devices, logic devices, components, processors, microprocessors, circuits, processing circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), Application-specific Standard Products (ASSPs), System-on-a-chip systems (SOCs), Complex Programmable Logic Devices (CPLDs), memory units, logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. Examples of software elements may include software components, programs, applications, computer programs, application programs, system programs, software development programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints, as desired for a given implementation.
  • The devices 310, 320 may execute communications operations or logic for the system 100 using communications component 340. The communications component 340 may implement any well-known communications techniques and protocols, such as techniques suitable for use with packet-switched networks (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), circuit-switched networks (e.g., the public switched telephone network), or a combination of packet-switched networks and circuit-switched networks (with suitable gateways and translators). The communications component 340 may include various types of standard communication elements, such as one or more communications interfaces, network interfaces, network interface cards (NIC), radios, wireless transmitters/receivers (transceivers), wired and/or wireless communication media, physical connectors, and so forth. By way of example, and not limitation, communication media 312 include wired communications media and wireless communications media. Examples of wired communications media may include a wire, cable, metal leads, printed circuit boards (PCB), backplanes, switch fabrics, semiconductor material, twisted-pair wire, co-axial cable, fiber optics, a propagated signal, and so forth. Examples of wireless communications media may include acoustic, radio-frequency (RF) spectrum, infrared and other wireless media.
  • FIG. 4 illustrates an embodiment of an operational environment 400 for the system 100. As shown in FIG. 4, the operating environment 400 includes an application 420, such as an enterprise software application, for processing input 410 and generating output 430.
  • The application 420 comprises one or more components 422-a where a represents any integer number. In one embodiment, the application 420 may comprise an interface component 422-1, a clustering component 422-2, a transform mechanism library 422-3, and a recognition component 422-4. The interface component 422-1 may be generally arranged to manage a user interface for the application 420, for example, by generating graphical data for presentation as a Graphical User Interface (GUI). The interface component 422-1 may generate the GUI to depict various elements, such as dialog boxes, HTML forms having rich text, and/or the like.
  • The clustering component 422-2 may be generally arranged to organize images into image groups or clusters. Some embodiments of the clustering component 422-2 execute the clustering process 200A of FIG. 2A and/or one or more of the colorspace conversion operations of scheme 200B of FIG. 2B and generates the image group model data 350 of FIG. 3. In various embodiments, the clustering component 422-2 identifies, for each image group, a particular colorspace transform having a higher likelihood than a current colorspace transform of success in edge detection for that group as outlined herein or otherwise suitable. In various embodiments, the clustering component 422-2 may perform the above-mentioned clustering process for a variety of edge detection techniques, resulting in sets of image groups where each set of image groups corresponds to a particular technique. Edge detection techniques vary in how boundaries are identified in an image; some techniques detect differences in color whereas other techniques measure another attribute. Some techniques differ with respect to how color differences are even measured. It is possible for one technique to alter certain steps and create multiple techniques.
  • The colorspace transform library 422-3 includes a plurality of colorspace transform mechanisms and may be generally arranged to provide a colorspace transform mechanism for application on an image, transforming that image into a transformed image in accordance with a different colorspace model than the image's original colorspace model. As described herein, the colorspace model refers to a technique for modeling an image's color data, such as in RGB or in LAB, or RGB to XYZ, or RGB to XYZ to another XYZ. In general, and as outlined in one or more embodiments herein, the colorspace transform mechanism performs mathematical operations to map a data point within the image's original/current colorspace model into a corresponding datapoint in accordance with the different colorspace model. This may involve converting the datapoint's value(s)—which are in one domain—into corresponding value(s) for the corresponding datapoint. As example, the colorspace transform may convert an RGB pixel having a tuple of RGB values into a LAB pixel having a tuple of LAB values, an RGB pixel having a tuple of RGB values into an XYZ pixel having a tuple of XYZ values, and/or an RGB pixel having a tuple of RGB values into an XYZ pixel having a tuple of XYZ values and again into another XYZ pixel having a tuple of other XYZ values. The pixels associated with the final conversion can define a color distribution for a scannable image, such as a matrix or matrix barcode that is used for a scan in association with an entity, object, or environment.
  • The recognition component 422-4, such as a suitable scanner, printer and/or camera or application for the same, may be generally arranged to execute an edge detection technique as part of a recognition operation on the transformed image. One example of a well-known recognition operation is Optical Character Recognition (OCR). The application 420 invokes the recognition component 422-4 to perform various tasks including scanning a matrix, e.g., matrix barcode or fiducial marker, for verifying an authenticity of an item and/or to obtain encoded information associated with the barcode. The recognition component 422-4 can be configured to contain a key, e.g. a mathematical equation or equations with specified inputs defining a colorspace conversion, such that it scans relevant colors reflected by the barcode, where the colors are based on one or more colorspace transformation techniques as outlined herein, where the key defines a final transformation that defines color-channels and a colorspace associated with colors of the scannable image, and where color-channels defined by the key each represent at least one bit of encoded data.
  • In various embodiments, the recognition component 422-4 can print or provide a schema for printing an image, e.g., barcode and/or fiducial marker, that contains one or more non-black and non-white colors and one or both of an ultraviolet layer and an infrared layer. The color-channels associated with each non-black and non-white color each can constitute at least one bit of data, and each one of the infrared and ultraviolet layers can each constitute one bit of data. In various embodiments, each one of the non-black and non-white colors are generated by a colorspace transformation mechanism or technique and are scannable by a key associated with the transformation mechanism. In various embodiments, the number of color-channels can be adjusted to be greater than or equal to four color-channels, as the recognition component 422-4 can be adjusted to scan any number of colors, including colors not perceptible to the human eye.
  • In various embodiments, the non-black and non-white color-channel can be used in conjunction with one or both of the infrared or ultraviolet layers on a scannable image, such as a matrix, matrix barcode and/or fiducial marker, where each of one of the color-channels, ultraviolet layer(s), and/or infrared layer(s) represent a bit of data and a different manner of encoding data into the image, and as such, six or more bits of data can be encoded into the image. In various embodiments, the ultraviolet layer may be printed or displayed first in relation to the infrared layers and the various layers associated with non-black and non-white color-channels to take advantage of the ultraviolet layer's properties.
  • In various embodiments, the image containing all or one of the layers associated with the non-black and non-white color-channel layers, the ultraviolet layers, and the infrared layers can be scanned by the recognition component 422-4 for a verification component, where the recognition component 422-4 may contain or receive a key that is based on an equation related to a colorspace conversion, e.g. Equation 1, where the colorspace conversion reveals the relevant color-channels with associated colors containing the information, in addition to one or more verification bits indicating whether the presence or absence of an ultraviolet and/or infrared layer is indicative of encoded information. Accordingly, the key and/or verification bit provides a manner of decoding information.
  • In various embodiments, application 420 is configured to contain the key and/or verification bit and provide an output 430 once the scan of the image, e.g., barcode, is verified locally. In various embodiments, the recognition component 422-4 can require an additional verification step of contacting a host system that contains one or more of the functionalities of system 100, to confirm, e.g., by one or more comparison steps, that the key and/or verification bit used by the recognition component 422-4 is accurate. If the key is accurate, and the scan is confirmed by the recognition component 422-4, then the output 430 of application 420 is one or more access, transfer, or receipt of information, including currency, personal, and/or financial information, to another entity.
  • In various embodiments, scanning the image, e.g., matrix, a matrix barcode, and/or fiducial marker can be done to protect a user from financial misappropriation. The recognition component 422-4 may perform the text or image recognition operation to determine whether the image, e.g., barcode, is valid, and relates the validity of the scan to a verification or access of information that includes any sensitive information, such as a password or social security number (SSN), according to some embodiments. The application 420 may invoke the recognition component 422-4 to scan an image, e.g. a barcode, prior to publishing social network content such that a potential failure to properly scan the image, e.g. the component scanning the image does not have a key that properly decodes it pursuant to the key related to the colorspace information and/or the bit indicating that an ultraviolet and/or infrared layer contains information, identification of sensitive information in that content prevents said publishing. In various other embodiments, the scanning of the image, e.g., barcode, can provide initiation of a financial transaction, e.g., transfer of any suitable electronic funds.
  • Included herein is a set of flow charts representative of exemplary methodologies for performing novel aspects of the disclosed architecture. While, for purposes of simplicity of explanation, the one or more methodologies shown herein, for example, in the form of a flow chart or flow diagram, are shown and described as a series of acts, it is to be understood and appreciated that the methodologies are not limited by the order of acts, as some acts may, in accordance therewith, occur in a different order and/or concurrently with other acts from that shown and described herein. For example, those skilled in the art may understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram. Moreover, not all acts illustrated in a methodology may be required for a novel implementation.
  • FIG. 5A illustrates one embodiment of a logic flow 500A. The logic flow 500A may be representative of some or all of the operations executed by one or more embodiments described herein.
  • In the illustrated embodiment shown in FIG. 5A, the logic flow 500A receives a representative dataset of a target, such as an entity, object, or environment 502. For example, the logic flow 500 may receive a representative dataset containing at least one of i) one or more images of a target and ii) one or more videos of the target, the target including at least one of i) an environment, ii) a live entity and iii) an object using any suitable camera or scanning device, where the representative dataset is contained in image group model data 350 or obtained directly by scanning the target using any suitable device, e.g., camera or video device 195 and/or scanning device 197. In various embodiments, the target may be an environment that contains a scannable image therein.
  • The logic flow 500A may process the representative dataset into a suitable representation of a color scheme, such as a histogram 504. For example, the logic flow 500 may examine image group model data 350, which contains captured data of a scanned environment. Once the logic flow 500 identifies the scanned data of the environment, the logic flow can process that data into a histogram of a particular colorspace, e.g., an RGB colorspace.
  • The logic flow 500A may identify the most prevalent colors of the environment utilizing the histogram 506. In various embodiments, the logic flow identifies the most prevalent colors in order to apply a colorspace transform mechanism for substantially maximizing edge detection for a scannable image, such as a matrix, matrix barcode, fiducial marker, etc.
  • The logic flow 500A may determine a related number of colors based on the histogram 508, e.g., the histogram is used to map to a first colorspace, where least prevalent and/or absent colors in relation to the most prevalent colors of the target are determined, and the least prevalent and/or absent colors form the basis for one or more color-channels in a second colorspace.
  • In various embodiments, the related plurality of colors can represent a range of colors between the most prevalent colors and the least prevalent colors and/or absent colors of the target, including sole colors that are absent in relation to the target and/or colors that are the least prevalent in association with the target. In various embodiments, in order to determine the related number of colors based, the logic flow may select and apply a colorspace transform mechanism to the image data associated with the histogram. As described herein, the image data includes color data configured in accordance with a colorspace model, e.g., the histogram can be used to create a colorspace representation of the target data. In some embodiments, the logic flow 500 applies the colorspace transform mechanism 180 of FIG. 1 by converting the image data into transformed image data comprising color data in accordance with another colorspace model that differs from the colorspace associated with the histogram. For example, the logic flow may create a histogram of the image data associated with the target, then use the histogram to create a first colorspace representation of the target, e.g., an RGB colorspace representation. Thereafter, as discussed below, the logic flow can perform one or more additional colorspace transformation techniques into other colorspaces, such as XYZ colorspaces or any other suitable colorspace that utilizes a tristimulus system.
  • In various embodiments, the logic flow 500A may perform a colorspace transform manipulating the color data of the original image data to enable efficient edge detection on the transformed image data. As explained below, the logic flow 500A may change the colorspace model to quickly identify boundaries, such as when two colors are close in proximity. The logic flow 500A examines each datapoint in the image, and for each location, the logic flow 500A identifies a color. In various embodiments, the colorspace conversion can be based on at least one set of color coordinates for each one of the most prevalent colors according to the another (or second) colorspace and determining at least one set of color coordinates corresponding to the related plurality of colors in the (second) another colorspace, where the at least one set of coordinates of the most prevalent plurality of colors being either one or both of perpendicular/orthogonal and a maximal distance away, with respect to another colorspace, to the at least one set of coordinates of the related colors. In various embodiments, the second colorspace can be considered a derivative colorspace of the first color space.
  • In various embodiments, this ensures that the colors used for a scannable image may maximize edge detection, as the maximal distance away between prevalent color-channels and colors of the target in the environment and other color-channels and colors (the related color-channels and colors) ensures that the related color-channels and colors are either absent in the target and/or least prevalent in the target. Additionally, if the related colors and color-channels are selected to be perpendicular or orthogonal in relation to the target color-channels and colors (and with respect to one another), this may further enhance edge detection.
  • In one example utilizing the one or more techniques outlined above, the logic flow 500A proceeds to identify two or more colors by prevalence in the target and configures them into one channel. Take, for instance, a first color and second color of first and second highest prevalence, respectively, where the first color becomes a minimum in the color channel and the second color becomes the maximum such that the boundary may be a transition between these colors. This boundary may be at least one pixel where the color changed from the first to the second color or vice versa. If the first color is set to zero (0) and the second color is set to two hundred and fifty-five (255), then, mathematically, this boundary may be located at pixel(s) that jumped between the minimum and maximum value; for example, there may be sharp division (i.e., thin boundary) in which at least two neighboring pixels transition immediately between 0 and 255.
  • As alluded to above, these color-channels can correspond to a first colorspace, e.g., RGB, where the first colorspace can be based on the first set of tristimulus values, and where the first-colorspace may have a color coordinates for representing colors of the target, e.g., the most prevalent colors of the target. The logic flow 500A may then identify one or more colors that are either unused or barely used (i.e., least prevalent or absent) and establish those colors in another channel to be opposite of the above-identified prevalent colors, where the new color-channel (or color-channels) forms the basis for a new colorspace, e.g., a new set of tristimulus values of an XYZ colorspace, and where the first colorspace is converted to the second colorspace.
  • Then, the logic flow 500A may perform one or more additional operations, e.g. configuring each color-channel of the new colorspace to be perpendicular or orthogonal to one another in the new colorspace model, make an additional conversion to a third colorspace, including an intermediary operation that filters out non-chromacity related features such as luminance or brightness channel, and/or perform an orientation operation in the second (or third) colorspace prior to making the color-channels perpendicular or orthogonal to each other (in order to maximize the distance between color-channels and thus enhancing edge detection).
  • The logic flow 500A may utilize the related colors of block 508 to create one or more scannable images 510, such as a matrix, matrix barcode, fiducial marker, or any other suitable image for scanning. In various embodiments, the related colors may be colors of each color-channel associated with the final colorspace conversion as discussed above, e.g. a plurality of color-channels and associated colors, as may be represented in an XYZ colorspace, that are either not prevalent in the target and/or are completely absent in the target, where, in various embodiments, the least prevalent and/or absent colors can be arranged orthogonally to each other to further enhance edge detection. In various embodiments, the scannable image may be a matrix barcode that is formed to reflect colors of each of the least prevalent and/or absent and/or orthogonal color-channels in relation to a target, e.g., environment containing the matrix barcode.
  • In various embodiments, the matrix barcode is embedded with information that is based on the colorspace conversions, e.g., each pixel or pixels associated with the matrix bar code is associated with a color-channel of the final colorspace, e.g. the XYZ colorspace with color-channels representing the least prevalent or absent colors of the environment, where each color-channel represents a bit of data, and where the number of color-channels can be three or more, four or more, etc. (as there are no limitations imposed by human perceptibility), and by extension the number of encoded bits can be three or more, four or more, etc.
  • In various embodiments, where four or more colors are used, each one of the four or more colors are distinct colors in relation to one another, and based on the colorspace techniques discussed herein and above, the four or more colors are derived from a plurality of coordinates corresponding to each one of the at least four distinct colors along a converted-to (derivative) colorspace, where the converted-to (derivative) colorspace contains a plurality of coordinates sets representing the at least four prevalent colors of the target, e.g., environment, and each of the four or more colors corresponds to a distinct coordinate set of the converted-to (derivative) colorspace.
  • In various embodiments, each of the four or more distinct colors are selected based on having a maximal opposite coordinate relationship with respect to at least one of the plurality of coordinate sets representing at least four prevalent colors in the target, e.g., environment.
  • There are a number of applicable edge detection techniques, and the edge detection technique 190 may be appropriate for the one colorspace model of the transformed image data while another edge detection technique may be appropriate for the original colorspace model. The embodiments are not limited to this example.
  • FIG. 5B illustrates one embodiment of a logic flow 500B. The logic flow 500B may be representative of some or all of the operations executed by one or more embodiments described herein.
  • In the illustrated embodiment shown in FIG. 5B, the logic flow may detect a matrix that includes one or more non-black and non-white colors, where each of the non-black and non-white colors is i) at least one of an absent color in relation to an environment and/or ii) at least one least prevalent color associated with the environment 515. In various embodiments, the matrix is a barcode constructed with one or more colorspace conversion techniques as outlined herein, e.g., the matrix barcode is derived from an RGB colorspace and a derivative colorspace of the RGB colorspace (a converted-to (derivative) colorspace from the RGB colorspace, such as an XYZ colorspace). In various embodiments, the derivative colorspace is an XYZ colorspace with a filtered luminance channel.
  • In various embodiments, the barcode can be scanned with any suitable component, e.g., a scanning device 197, that has a suitable key, e.g., tristimulus equations associated with a conversion to an XYZ colorspace, that reveals the color-channels with associated colors that are associated with the scannable portions of the matrix barcode, including, in various embodiments, information encoded in the matrix barcode. In various embodiments, the barcode can include four or more distinct colors each associated with at least four-distinct color-channels, where each of the colors is different from one another and different from the most prevalent colors of the environment. In various embodiments, the colors and color-channels of the barcode can be computed according to coordinate relationships between the most prevalent colors and the least prevalent and/or absent colors in the derivative colorspace, including a maximal distance between the most prevalent colors and the least prevalent and/or absent colors. Additional or different colorspace conversion techniques can be used as discussed herein, and this is merely one example consistent with the present disclosure.
  • In various embodiments, the barcode can be printed and/or embedded on a physical medium, e.g., a physical surface or material, using any suitable component, e.g., printing device 199, with the least prevalent and/or absent colors, and the barcode can be scanned along the surface of the physical surface. In other embodiments, any suitable computer device, including a computer, laptop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, where the barcode can be scanned along a surface of the computer display.
  • The logic flow 500B may transmit the result of the scan to any suitable computer device 520 as discussed herein, including an indication as to whether or not the scan was of the barcode was successful, and any encoded information associated therewith was obtained.
  • FIG. 5C illustrates one embodiment of a logic flow 500C. The logic flow may be representative of some or all of the operations executed by one or more embodiments described herein.
  • In the illustrated embodiment shown in FIG. 5C, the logic flow 500C carries out one or more of the operations of flow 500C, wherein one embodiment it carries out the operations of 502, 504, 506, and 508.
  • The logic flow 500C may utilize the related colors to produce a scannable image 530, such as a matrix, matrix barcode, fiducial marker, or any other suitable image for scanning, where the scannable image can, in addition to including non-black and non-white colors (such as the least prevalent and/or absent colors associated with a target, e.g. an environment), can include one or both of an ultraviolet layer and an infrared layer. In various embodiments, the matrix, matrix barcode, fiducial marker, or any other suitable image can be printed and/or embedded on a physical surface using any suitable component, e.g. printing device 199, with the least prevalent and/or absent colors and an infrared and/or ultraviolet layer, and the barcode can be scanned along the surface of the physical surface. In other embodiments, any suitable computer device, including a computer, labtop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, the ultraviolet layer and/or the infrared layer, where the matrix, matrix barcode, fiducial marker, or any other suitable image can be scanned along a surface of the computer display.
  • In various embodiments, the ultraviolet layer may be printed first along the physical surface and/or may form the top layer generated on a computer screen in order to maximize the benefits associated with ultraviolet light. In various embodiments, the colors of the scannable image need not be colors that have a relationship with the environment and/or not based on colorspace conversion techniques and can be any colors, including standard black and white colors, with a scannable image containing both an infrared and ultraviolet layer for detection.
  • FIG. 5D illustrates one embodiment of a logic flow 500D. The logic flow 500D may be representative of some or all of the operations executed by one or more embodiments described herein.
  • In the illustrated embodiment shown in FIG. 5D, the logic flow may detect a scannable image, e.g., a matrix, that includes one or more non-black and non-white colors, where each of the non-black and non-white colors are at least one of an i) an absent color in relation to an environment and/or ii) a least prevalent color associated with the environment, in addition to one or both of an ultraviolet layer and/or an infrared layer 540. In various embodiments, the matrix is a barcode constructed with one or more colorspace conversion techniques as outlined herein, e.g., as discussed with respect to FIG. 5B, with the addition of an ultraviolet layer and/or infrared layer.
  • In various embodiments, the scannable image, e.g. barcode, can be scanned with any suitable component, e.g. a scanning device 197, that has a suitable key, e.g. tristimulus equations associated with a conversion to an XYZ colorspace, that reveals the color-channels with associated colors that are associated with the scannable portions of the matrix barcode, including, in various embodiments, information encoded in the matrix barcode. In addition to the key, any suitable component, e.g., scanning device 197, can also have a verification bit indicating whether the ultraviolet layer and/or infrared layer is associated with information, and if so, performs the scan and/or decodes the information based on the verification bit. In various embodiments, the barcode can include four or more distinct colors each associated with at least four distinct color-channels, where each of the colors are different from one another and different to the most prevalent colors of the environment, in addition to also having one or both the ultraviolet layer and/or the infrared layer, and as such, the scan can be a scan of six or more bits of information.
  • In various embodiments, the barcode can be printed and/or embedded on a physical surface using any suitable component, e.g., printing device 199, with the least prevalent and/or absent colors, and the barcode can be scanned along the surface of the physical surface. In other embodiments, any suitable computing device, including a computer, labtop, or tablet (as shown in FIG. 7 provided for below) can be configured to generate a scannable barcode that reflects the least prevalent or absent colors, where the barcode can be scanned along a surface of the computer display. In various embodiments, the printing of the scannable image, e.g., barcode, can be such that the topmost layer may be an ultraviolet layer and any associated scan may account for the ultraviolet layer first. Similarly, in various embodiments, if the scannable image is generated by a computer device and displayed by a computer display, the first layer displayed by the computer device can be the ultraviolet layer.
  • The logic flow 500D may transmit the result of the scan to any suitable computer device 550 as discussed herein, including an indication as to whether or not the scan was of the barcode was successful, and any encoded information associated in addition to that was obtained.
  • FIG. 6A illustrates one technique 600A of forming a scannable image in accordance with at least one embodiments of the present disclosure. Scannable image layers 605 a, 610 a, and 615 a each represent a layer of a scannable image, such as a barcode, associated with one or more colors. Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 a, 610 a, 615 a in order to produce layers 620 a, 625 a, and 630 a, and layers 620 a, 625 a, and 630 a may be consolidated into a single scannable image, e.g., barcode, 635 a. In various embodiments, the scannable layers 620 a, 625 a, and 630 a may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 635 a, wherein various embodiments one or more color-channels associated with colors of 620 a, 625 a, and 630 a may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors. The scannable image 635 a can be printed on a physical surface of a target using any suitable device and/or generated by any suitable computing device for display on a computer display.
  • Although the embodiment of FIG. 6A illustrates performing a transformation technique with respect to color schemes that are associated with existing scannable image layers 605 a, 610 a, and/or 615 a, scannable image 635 a can be generated from scratch without converting from existing images, e.g., a target can be scanned, colorspaces associated therewith determined therefrom, and a final scannable image 635 a can be produced by performing one or more colorspace transformations on the colorspaces as disclosed herein or otherwise suitable.
  • FIG. 6B illustrates one technique 600B of forming a scannable image in accordance with at least one embodiments of the present disclosure. Scannable image layers 605 b, 610 b, and 615 b each represent a layer of a scannable image, such as a barcode, associated with one or more colors. Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 b, 610 b, 615 b in order to produce layers 620 b, 625 b, and 630 b, and layers 620 b, 625 b, and 630 b may be consolidated into a single scannable image 635 b, e.g., barcode, 635 b. In various embodiments, the scannable layers 620 b, 625 b, and 630 b may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 635 b, wherein various embodiments one or more color-channels associated with colors of 620 b, 625 b, and 630 b may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors. In various embodiments, at least one layer, e.g. 630 b, can be made with ultraviolet or infrared ink or generated using ultraviolet or infrared light such that it contains an additional channel of information, e.g., an ultraviolet layer or infrared layer of information, which can absorb, reflect, project, and/or illuminate ultraviolet or infrared light, wherein various embodiments the ultraviolet layer or infrared layer 630 b may be the first layer of image 635 b. In various embodiments, the ultraviolet or infrared layer 630 b may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 635 b, and in various embodiments, only an ultraviolet channel may be associated with the ultraviolet layer 630 b.
  • In various embodiments, the scannable image 635 b can be printed on a physical surface of a target using any suitable device and/or generated by any suitable computer device for display on a computer display.
  • In various embodiments, the scannable image 635 b is a fiducial marker that takes advantage of the inherent orienting features of ultraviolet and/or infrared light when being scanned by a suitable device that can detect either one or both of ultraviolet and/or infrared light. In various embodiments, when a suitable device, e.g., scanning device 197, scans a fiducial marker 635 b that reflects ultraviolet and/or infrared light, the spatial relationship of the object associated with the fiducial maker 635 b, e.g. an object with the fiducial marker labeled thereon and/or a computer display generating the fiducial marker 635 b, in relation to the scanning device 197 and other objects in an environment containing the device is easier to ascertain because of the inherent properties associated with the reflection and detection of ultraviolet and/or infrared light.
  • FIG. 6C illustrates one technique 600C of forming a scannable image in accordance with at least one embodiments of the present disclosure. Scannable image layers 605 c, 610 c, 615 c, and 620 c each represent a layer of a scannable image, such as a barcode, associated with one or more colors. Any suitable component as disclosed herein may perform one or more colorspace transformation techniques on each scannable image layers 605 c, 610 c, 615 c, and 620 c in order to produce layers 625 c, 630 c, 635 c and 640 c, and layers 625 c, 630 c, 635 c and 640 c may be consolidated into a single scannable image, e.g., barcode, 645 c. In various embodiments, the scannable layers 625 c, 630 c, 635 c and 640 c may each be associated with a color-channel that represents one or more colors that are absent and/or not prevalent in relation to a target that may be associated with the scannable image 645 c, where in various embodiments one or more color-channels associated with colors of 625 c, 630 c, 635 c and 640 c may be orthogonal or perpendicular in relation to one another and with respect to colorspaces representing those colors.
  • In various embodiments, at least one layer, e.g. 635 c, can be made with infrared ink or generated using infrared light such that it contains an additional channel of information, e.g., an ultraviolet layer of information, which can absorb, reflect, project, and/or illuminate infrared light, where in various embodiments the infrared layer 630 c may be the first layer of image 635 c. In various embodiments, the infrared layer 630 c may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 645 c, and in various embodiments, only an infrared channel may be associated with the infrared layer 630 d. In various embodiments, at least one layer, e.g. 640 c, can be made with ultraviolet ink or generated using ultraviolet light such that it contains an additional channel of information, e.g., an ultraviolet layer of information, which can absorb, reflect, project, and/or illuminate ultraviolet light, where in various embodiments the ultraviolet layer 640 c may be the first layer of image 645 c. In various embodiments, the ultraviolet layer 640 c may contain a color-channel layer representing various colors, including colors that are not prevalent and/or absent from a target to be associated with the scannable image 645 c, and in various embodiments, only an ultraviolet channel may be associated with the ultraviolet layer 640 c.
  • In various embodiments, the scannable image 645 c is a fiducial marker that takes advantage of the inherent orienting features of ultraviolet and/or infrared light when being scanned by a suitable device that can detect either one or both of ultraviolet and/or infrared light. In various embodiments, when a suitable device, e.g., scanning device 197, scans a fiducial marker 645 c that reflects both ultraviolet and infrared light, the spatial relationship of the object associated with the fiducial maker 645 c, e.g. an object with the fiducial marker labeled thereon and/or a computer display generating the fiducial marker 645 c, in relation to the scanning device 197 and other objects in an environment containing the device is easier to ascertain or detect because of the inherent properties associated with the reflection and detection of ultraviolet and/or infrared light. In various embodiments, where fiducial marker 645 c utilizes both ultraviolet and infrared light, the presence of both operates as a fail-safe if the functionality of the scanning device 197 is compromised, and/or if an initial scan fails to detect one or the other.
  • In various embodiments, the scannable image 645 c may include both an infrared layer 635 c and an ultraviolet layer 640 c, where the printing or generating of layer 645 c may be such that the ultraviolet layer 640 c may be the first layer in order to take advantage of the characteristics associated with ultraviolet light. Although at least one embodiment provided above indicates that either one or both of layers 635 c and 640 c can include color-channel information, e.g., scannable colors that have a relationship with a target, in various embodiments, layers 635 c and 640 c can be associated strictly with infrared and/or ultraviolet information respectively. Moreover, in various embodiments, the colors of layer 620 c, 625 c, and 630 c do not have to be layer that has a relationship with the target, and in various embodiments, said layers can be composed of black and white colors and/or other colors unrelated to the target and/or not based on colorspace conversion techniques.
  • FIG. 7 illustrates a computer or tablet system 700 for generating and scanning a scannable image 740. The tablet system includes a tablet 702 for generating a scannable image 740, e.g., barcode, where the tablet 702 includes applications 705A-E, application N, and application 420, where one embodiment of application 420 is described in greater detail above with respect to FIG. 4. The tablet 702 may include one or more user interface devices 720 which a user can use to interface with the tablet 702. The tablet 702 can generate a scannable image 740 that includes one or both of an ultraviolet and infrared layer. The tablet 702 can be configured to ensure that the top layer is an ultraviolet layer to take advantage of the properties inherent with ultraviolet light. The image can further include one or more colors layer, including white and black layers. The image can further include one or more non-black and non-white colors layers that are related to colors associated with the environment where the tablet is located, e.g., the tablet can be configured to have a camera with an application, e.g., 420, that can scan an environment and produce a scannable image 740 with colors related to that environment. In various embodiments, the colors related to the environment can be colors based on one or more colorspace transformation techniques as discussed herein, including colors that are least prevalent and/or absent from the environment containing the tablet 702 and determined by one or more colorspace conversions.
  • The system 700 can further include a camera or scanning device c750 that can scan the scannable image 740, wherein various embodiments the camera or scanning device c750 may include application 420 (as discussed above), and/or a colorspace key and/or infrared verification bit and/or ultraviolet verification bit as disclosed herein, and in order to perform a valid scan of scannable image 740 and/or obtain any encoded information associated therewith.
  • FIG. 8 illustrates an embodiment of a graphical user interface (GUI) 800 for an application of the system 100. In some embodiments, the user interface 800 is configured for the application 420 of FIG. 4.
  • The GUI 800, as illustrated in FIG. 8, includes several components, such as a toolbar 802 and GUI elements. The toolbar 802 includes, as one example tool, a recognize text tool 804 that, when invoked, scans an image 806, e.g., a barcode generated from one or more colorspace techniques and/or containing one or both of an ultraviolet layer and/or infrared layer as outlined herein. The scan can be using a key and/or verification bit in order for a valid scan to take place, where a proper scan may operate as a security measure to access and/or identify sensitive information 808. As described herein, the appropriate colorspace transform mechanism provides the most accurate edge detection results because an underlying colorspace model has a higher likelihood at edge detection than any other applicable colorspace model, and the barcode can be generated with this in mind.
  • FIG. 9 illustrates an embodiment of an exemplary computing architecture 900 suitable for implementing various embodiments as previously described. In one embodiment, the computing architecture 900 may comprise or be implemented as part of an electronic device. Examples of an electronic device may include those described with reference to FIG. 3, among others. The embodiments are not limited in this context.
  • As used in this application, the terms “system” and “component” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution, examples of which are provided by the exemplary computing architecture 900. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
  • The computing architecture 900 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth. The embodiments, however, are not limited to implementation by the computing architecture 900.
  • As shown in FIG. 9, the computing architecture 900 comprises a processing unit 904, a system memory 906 and a system bus 908. The processing unit 904 can be any of various commercially available processors, including without limitation an AMD® Athlon®, Duron® and Opteron® processors; ARM® application, embedded and secure processors; IBM® and Motorola® DragonBall® and PowerPC® processors; IBM and Sony® Cell processors; Intel® Celeron®, Core (2) Duo®, Itanium®, Pentium®, Xeon®, and XScale® processors; and similar processors. Dual microprocessors, multi-core processors, and other multi-processor architectures may also be employed as the processing unit 904.
  • The system bus 908 provides an interface for system components including, but not limited to, the system memory 906 to the processing unit 904. The system bus 908 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures. Interface adapters may connect to the system bus 908 via a slot architecture. Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
  • The computing architecture 900 may comprise or implement various articles of manufacture. An article of manufacture may comprise a computer-readable storage medium to store logic. Examples of a computer-readable storage medium may include any tangible media capable of storing electronic data, including volatile memory or non-volatile memory, removable or non-removable memory, erasable or non-erasable memory, writeable or re-writeable memory, and so forth. Examples of logic may include executable computer program instructions implemented using any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, object-oriented code, visual code, and the like. Embodiments may also be at least partly implemented as instructions contained in or on a non-transitory computer-readable medium, which may be read and executed by one or more processors to enable performance of the operations described herein.
  • The system memory 906 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory, polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information. In the illustrated embodiment shown in FIG. 9, the system memory 906 can include non-volatile memory 910 and/or volatile memory 912. A basic input/output system (BIOS) can be stored in the non-volatile memory 910.
  • The computer 902 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 914, a magnetic floppy disk drive (FDD) 916 to read from or write to a removable magnetic disk 918, and an optical disk drive 920 to read from or write to a removable optical disk 922 (e.g., a CD-ROM or DVD). The HDD 914, FDD 916 and optical disk drive 920 can be connected to the system bus 908 by a HDD interface 924, an FDD interface 926 and an optical drive interface 928, respectively. The HDD interface 924 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and IEEE 1394 interface technologies.
  • The drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth. For example, a number of program modules can be stored in the drives and memory units 910, 912, including an operating system 930, one or more application programs 932, other program modules 934, and program data 936. In one embodiment, the one or more application programs 932, other program modules 934, and program data 936 can include, for example, the various applications and/or components of the system 100.
  • A user can enter commands and information into the computer 902 through one or more wire/wireless input devices, for example, a keyboard 938 and a pointing device, such as a mouse 940. Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like. These and other input devices are often connected to the processing unit 904 through an input device interface 942 that is coupled to the system bus 908, but can be connected by other interfaces such as a parallel port, IEEE 1394 serial port, a game port, a USB port, an IR interface, and so forth.
  • A monitor 944 or other type of display device is also connected to the system bus 908 via an interface, such as a video adaptor 946. The monitor 944 may be internal or external to the computer 902. In addition to the monitor 944, a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
  • The computer 902 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 948. The remote computer 948 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 902, although, for purposes of brevity, only a memory/storage device 950 is illustrated. The logical connections depicted include wire/wireless connectivity to a local area network (LAN) 952 and/or larger networks, for example, a wide area network (WAN) 954. Such LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
  • When used in a LAN networking environment, the computer 902 is connected to the LAN 952 through a wire and/or wireless communication network interface or adaptor 956. The adaptor 956 can facilitate wire and/or wireless communications to the LAN 952, which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 956.
  • When used in a WAN networking environment, the computer 902 can include a modem 958, or is connected to a communications server on the WAN 954, or has other means for establishing communications over the WAN 954, such as by way of the Internet. The modem 958, which can be internal or external and a wire and/or wireless device, connects to the system bus 908 via the input device interface 942. In a networked environment, program modules depicted relative to the computer 902, or portions thereof, can be stored in the remote memory/storage device 950. It may be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
  • The computer 902 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.11 over-the-air modulation techniques). This includes at least Wi-Fi (or Wireless Fidelity), WiMax, and Bluetooth™ wireless technologies, among others. Thus, the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices. Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity. A Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
  • FIG. 10 illustrates a block diagram of an exemplary communications architecture 1000 suitable for implementing various embodiments as previously described. The communications architecture 1000 includes various common communications elements, such as a transmitter, receiver, transceiver, radio, network interface, baseband processor, antenna, amplifiers, filters, power supplies, and so forth. The embodiments, however, are not limited to implementation by the communications architecture 1000.
  • As shown in FIG. 10, the communications architecture 1000 comprises includes one or more clients 1002 and servers 1004. The clients 1002 may implement the client device 310. The servers 1004 may implement the server device 950. The clients 1002 and the servers 1004 are operatively connected to one or more respective client data stores 1008 and server data stores 1010 that can be employed to store information local to the respective clients 1002 and servers 1004, such as cookies and/or associated contextual information.
  • The clients 1002 and the servers 1004 may communicate information between each other using a communication framework 1006. The communications framework 1006 may implement any well-known communications techniques and protocols. The communications framework 1006 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
  • The communications framework 1006 may implement various network interfaces arranged to accept, communicate, and connect to a communications network. A network interface may be regarded as a specialized form of an input output interface. Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1000 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like. Further, multiple network interfaces may be used to engage with various communications network types. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks. Should processing requirements dictate a greater amount speed and capacity, distributed network controller architectures may similarly be employed to pool, load balance, and otherwise increase the communicative bandwidth required by clients 1002 and the servers 1004. A communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
  • Some embodiments may be described using the expression “one embodiment” or “an embodiment” along with their derivatives. These terms mean that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment. Further, some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. These terms are not necessarily intended as synonyms for each other. For example, some embodiments may be described using the terms “connected” and/or “coupled” to indicate that two or more elements are in direct physical or electrical contact with each other. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.
  • It is emphasized that the Abstract of the Disclosure is provided to allow a reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it may not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein,” respectively. Moreover, the terms “first,” “second,” “third,” and so forth, are used merely as labels, and are not intended to impose numerical requirements on their objects.
  • What has been described above includes examples of the disclosed architecture. It is, of course, not possible to describe every conceivable combination of components and/or methodologies, but one of ordinary skill in the art may recognize that many further combinations and permutations are possible. Accordingly, the novel architecture is intended to embrace all such alterations, modifications and variations that fall within the spirit and scope of the appended claims.

Claims (20)

1. A method, comprising:
detecting a matrix on display via a physical medium and associated with an environment, wherein the matrix includes a plurality of non-black and non-white colors, wherein each one of the plurality of non-black and non-white colors is a least prevalent color, of a plurality of prevalent colors in the environment, wherein the matrix is further based on a first plurality of colors derived from a plurality of least prevalent colors in the environment.
2. The method of claim 1, wherein the matrix is a matrix barcode and the matrix barcode is derived from a red-green-blue (RGB) colorspace and a derivative colorspace of the RGB colorspace, wherein the derivative colorspace includes a filtered luminance channel.
3. The method of claim 2, wherein the matrix barcode includes at least four distinct colors, each of the four distinct colors being different with respect to one another.
4. The method of claim 2, wherein the matrix barcode is displayed by a computer display and the detection of the matrix barcode is along a surface of the computer display.
5. The method of claim 2, wherein the matrix barcode is embedded on a physical material and the detection is along a surface of the physical material.
6. The method of claim 3, wherein each of the at least four distinct colors are different than each one of a plurality of most prevalent colors in the environment.
7. The method of claim 3, wherein the environment includes at least four prevalent colors, and wherein each one of the at least four distinct colors being derived from a plurality of coordinates corresponding to each one of the at least four distinct colors along the derivative colorspace, and wherein the derivative colorspace contains a plurality of coordinates sets representing the at least four prevalent colors.
8. The method of claim 7, wherein the at least four distinct colors each correspond to a distinct coordinate set of the derivative colorspace, and wherein each of the at least four distinct colors are selected based on having a maximal opposite coordinate relationship with respect to at least one of the plurality of coordinate sets representing the at least four prevalent colors.
9. (canceled)
10. The method of claim 1, wherein the matrix is a matrix barcode and the matrix barcode is derived from a first colorspace and a derivative colorspace of the first colorspace.
11. The method of claim 10, wherein the derivative colorspace is based on a colorspace conversion.
12. (canceled)
13. The method of claim 1, wherein the matrix is a matrix barcode.
14. An apparatus, comprising:
a processor; and
a memory storing instructions which when executed by the processor cause the processor to:
detect a matrix on display via a physical medium and associated with an environment, wherein the matrix includes a plurality of non-black and non-white colors, wherein each one of the plurality of non-black and non-white colors is a least prevalent color associated with the environment, and wherein the matrix includes at least four distinct colors, each of the at least four distinct colors being different than each of a plurality of most prevalent colors in the environment.
15. The apparatus of claim 14, wherein the matrix is a matrix barcode and the matrix barcode is derived from a red-green-blue (RGB) colorspace and a derivative colorspace of the RGB colorspace, wherein the derivative colorspace includes a filtered luminance channel.
16. The apparatus of claim 15, wherein each of the four colors are different with respect to one another.
17. A non-transitory computer-readable storage medium storing computer-readable program code executable by a processor to cause the processor to:
detect a matrix on display via a physical medium and associated with an environment, wherein the matrix includes a plurality of non-black and non-white colors, wherein each one of the plurality of non-black and non-white colors is a least prevalent color, of a plurality of prevalent colors in the environment, wherein the matrix is further based on a first plurality of colors derived from a plurality of least prevalent colors in the environment.
18. The computer-readable storage medium of claim 17, wherein the matrix is a matrix barcode and the matrix barcode is derived from a red-green-blue (RGB) colorspace and a derivative colorspace of the RGB colorspace, wherein the derivative colorspace includes a filtered luminance channel.
19. The computer-readable storage medium of claim 18, wherein the matrix barcode includes at least four distinct colors, each of the four colors being different with respect to one another.
20. The computer-readable storage medium of claim 18, wherein the matrix barcode is displayed by a computer display and the detection of the matrix barcode is along a surface of the computer display.
US16/690,064 2019-03-18 2019-11-20 Optimizing detection of images in relation to targets based on colorspace transformation techniques Active US10796122B1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
US16/690,064 US10796122B1 (en) 2019-03-18 2019-11-20 Optimizing detection of images in relation to targets based on colorspace transformation techniques
US17/011,283 US11314958B2 (en) 2019-03-18 2020-09-03 Detecting in an environment a matrix having a least prevalent color
US17/706,758 US11630968B2 (en) 2019-03-18 2022-03-29 Matrix barcode having a plurality of colors and a least prevalent color
US18/120,571 US11954545B2 (en) 2019-03-18 2023-03-13 System and method using a histogram and colorspaces to create a matrix barcode
US18/616,267 US20240232563A1 (en) 2019-03-18 2024-03-26 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US16/357,231 US10534948B1 (en) 2019-03-18 2019-03-18 Optimizing detection of images in relation to targets based on colorspace transformation techniques
US16/690,064 US10796122B1 (en) 2019-03-18 2019-11-20 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/357,231 Division US10534948B1 (en) 2019-03-18 2019-03-18 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US17/011,283 Continuation US11314958B2 (en) 2019-03-18 2020-09-03 Detecting in an environment a matrix having a least prevalent color

Publications (2)

Publication Number Publication Date
US20200302137A1 true US20200302137A1 (en) 2020-09-24
US10796122B1 US10796122B1 (en) 2020-10-06

Family

ID=69141077

Family Applications (6)

Application Number Title Priority Date Filing Date
US16/357,231 Active US10534948B1 (en) 2019-03-18 2019-03-18 Optimizing detection of images in relation to targets based on colorspace transformation techniques
US16/690,064 Active US10796122B1 (en) 2019-03-18 2019-11-20 Optimizing detection of images in relation to targets based on colorspace transformation techniques
US17/011,283 Active US11314958B2 (en) 2019-03-18 2020-09-03 Detecting in an environment a matrix having a least prevalent color
US17/706,758 Active US11630968B2 (en) 2019-03-18 2022-03-29 Matrix barcode having a plurality of colors and a least prevalent color
US18/120,571 Active US11954545B2 (en) 2019-03-18 2023-03-13 System and method using a histogram and colorspaces to create a matrix barcode
US18/616,267 Pending US20240232563A1 (en) 2019-03-18 2024-03-26 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US16/357,231 Active US10534948B1 (en) 2019-03-18 2019-03-18 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Family Applications After (4)

Application Number Title Priority Date Filing Date
US17/011,283 Active US11314958B2 (en) 2019-03-18 2020-09-03 Detecting in an environment a matrix having a least prevalent color
US17/706,758 Active US11630968B2 (en) 2019-03-18 2022-03-29 Matrix barcode having a plurality of colors and a least prevalent color
US18/120,571 Active US11954545B2 (en) 2019-03-18 2023-03-13 System and method using a histogram and colorspaces to create a matrix barcode
US18/616,267 Pending US20240232563A1 (en) 2019-03-18 2024-03-26 Optimizing detection of images in relation to targets based on colorspace transformation techniques

Country Status (8)

Country Link
US (6) US10534948B1 (en)
JP (2) JP7454588B2 (en)
KR (1) KR20210137103A (en)
CN (2) CN116823971A (en)
CA (1) CA3130865C (en)
DE (1) DE112020001345T5 (en)
GB (3) GB2608346B (en)
WO (1) WO2020190789A1 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10867226B1 (en) 2019-11-04 2020-12-15 Capital One Services, Llc Programmable logic array and colorspace conversions
US10878600B1 (en) 2019-12-10 2020-12-29 Capital One Services, Llc Augmented reality system with color-based fiducial marker utilizing local adaptive technology
US10977535B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing infrared light
US10977462B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet light
US10977536B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet and infrared light
US11003968B2 (en) 2019-04-24 2021-05-11 Capital One Services, Llc Colorspace encoding multimedia data on a physical page
US11024256B2 (en) * 2019-06-20 2021-06-01 Capital One Services, Llc Adaptive image display based on colorspace conversions
US11184150B2 (en) 2019-04-18 2021-11-23 Capital One Services, Llc Transmitting encoded data along transmission mediums based on colorspace schemes
US11200751B2 (en) 2019-07-25 2021-12-14 Capital One Services, Llc Augmented reality system with color-based fiducial marker
US11302036B2 (en) 2020-08-19 2022-04-12 Capital One Services, Llc Color conversion between color spaces using reduced dimension embeddings
US11314958B2 (en) 2019-03-18 2022-04-26 Capital One Services, LLC. Detecting in an environment a matrix having a least prevalent color
US11342943B2 (en) 2019-10-25 2022-05-24 Capital One Services, Llc Data encoding with error-correcting code pursuant to colorspace schemes
US11417075B2 (en) 2019-11-14 2022-08-16 Capital One Services, Llc Object detection techniques using colorspace conversions
EP4042221A4 (en) * 2019-10-02 2023-11-15 ChemImage Corporation Fusion of molecular chemical imaging with rgb imaging

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10833852B1 (en) 2019-10-03 2020-11-10 Capital One Services, Llc Encoded data along tape based on colorspace schemes
CN113158715A (en) * 2020-11-05 2021-07-23 西安天伟电子系统工程有限公司 Ship detection method and device
CN114692800A (en) * 2020-12-29 2022-07-01 华为技术有限公司 Two-dimensional code generation method and related equipment
USD1043682S1 (en) * 2021-06-10 2024-09-24 Zappar Limited World marker mat
US20230206016A1 (en) * 2021-12-23 2023-06-29 Datalogic Usa, Inc. Anti-theft scanning system and methods of detecting theft
CN115439509B (en) * 2022-11-07 2023-02-03 成都泰盟软件有限公司 Multi-target tracking method and device, computer equipment and storage medium

Family Cites Families (177)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AUPQ131399A0 (en) 1999-06-30 1999-07-22 Silverbrook Research Pty Ltd A method and apparatus (NPAGE02)
AU570439B2 (en) * 1983-03-28 1988-03-17 Compression Labs, Inc. A combined intraframe and interframe transform coding system
US7171016B1 (en) 1993-11-18 2007-01-30 Digimarc Corporation Method for monitoring internet dissemination of image, video and/or audio files
JP3436958B2 (en) 1993-12-08 2003-08-18 株式会社東芝 Image input device
US5724450A (en) 1994-09-30 1998-03-03 Apple Computer, Inc. Method and system for color image compression in conjunction with color transformation techniques
US6119943A (en) 1994-12-12 2000-09-19 Moore Business Forms, Inc. Multi-layer bar code arrangement using wavelength separation
US6590996B1 (en) 2000-02-14 2003-07-08 Digimarc Corporation Color adaptive watermarking
US5678033A (en) 1995-06-06 1997-10-14 Moledina; Riaz A. Multi-stage interpolation processor
US7770013B2 (en) 1995-07-27 2010-08-03 Digimarc Corporation Digital authentication with digital and analog documents
US6098882A (en) 1996-03-01 2000-08-08 Cobblestone Software, Inc. Variable formatting of digital data into a pattern
JP3676887B2 (en) 1996-08-08 2005-07-27 理想科学工業株式会社 Color two-dimensional code and color two-dimensional code creation device
US5818032A (en) 1997-01-03 1998-10-06 Sun; Tsu-Hung Tom Encoded color halftone micro-dots for high density digital information storage
EP1016027B1 (en) 1997-04-08 2005-06-15 ZIH Corporation Distortion resistant double-data correcting color transition barcode and method of generating and using same
US6775417B2 (en) 1997-10-02 2004-08-10 S3 Graphics Co., Ltd. Fixed-rate block-based image compression with inferred pixel values
JP3813387B2 (en) 1998-07-28 2006-08-23 富士写真フイルム株式会社 Information embedding method and apparatus, and recording medium
US6354502B1 (en) 1999-04-23 2002-03-12 Primera Technology, Inc. Continuous color tone infrared detected barcodes
JP2000311243A (en) 1999-04-28 2000-11-07 Sony Corp Image color correction method and device
KR100323364B1 (en) * 1999-07-30 2002-02-19 박호군 A method for extracting characterized vectors in color image and a retrieval method using the characterized vectors
US6711291B1 (en) * 1999-09-17 2004-03-23 Eastman Kodak Company Method for automatic text placement in digital images
WO2001024106A1 (en) 1999-09-27 2001-04-05 Sicpa Holding S.A. Multi-dimensional barcode and apparatus for reading a multi-dimensional barcode
JP4212742B2 (en) 1999-12-14 2009-01-21 富士ゼロックス株式会社 Color image processing method and color image processing apparatus
US6572025B1 (en) * 2000-05-10 2003-06-03 Japan Gain The Summit Co., Ltd. Information code product, manufacturing device and method for manufacturing the same, information code reading device, authentication system, authentication terminal, authentication server, and authentication method
EP1312030B1 (en) 2000-07-25 2011-08-24 Digimarc Corporation Authentication watermarks for packaged products
US6963659B2 (en) 2000-09-15 2005-11-08 Facekey Corp. Fingerprint verification system utilizing a facial image-based heuristic search method
US20020126328A1 (en) 2001-03-09 2002-09-12 Lehmeier Michelle R. Method and apparatus for matching color image data with a corresponding color in a defined color space
US20030176785A1 (en) * 2002-02-04 2003-09-18 Damage Control Surgical Technologies, Inc. Method and apparatus for emergency patient tracking
JP2003323610A (en) 2002-03-01 2003-11-14 Nec Corp Color correcting method and device, for projector
US6956967B2 (en) 2002-05-20 2005-10-18 Eastman Kodak Company Color transformation for processing digital images
JP2004015547A (en) 2002-06-07 2004-01-15 Canon Inc Image encrypting device, image encrypting method, decrypting device, decrypting method, program, and storage medium
US20030235923A1 (en) 2002-06-21 2003-12-25 Jurik Franklin A. Acceptance testing method for sets of multiple colored workpieces
US8619077B1 (en) 2002-07-03 2013-12-31 Matrox Graphics Inc. Efficient execution of color space processing functions in a graphics processing unit
KR100467610B1 (en) 2002-09-06 2005-01-24 삼성전자주식회사 Method and apparatus for improvement of digital image quality
JP2004180013A (en) 2002-11-27 2004-06-24 Toshiba Tec Corp Color conversion device and color conversion method
US6757883B1 (en) 2002-12-11 2004-06-29 Lsi Logic Corporation Estimating free space in IC chips
JP3996520B2 (en) 2003-01-30 2007-10-24 株式会社デンソーウェーブ Two-dimensional information code and generation method thereof
US7077332B2 (en) * 2003-03-19 2006-07-18 Translucent Technologies, Llc Media verification system
US7085413B2 (en) 2003-04-04 2006-08-01 Good News Enterprises Limited Image background detection and removal
US8045219B2 (en) 2003-06-05 2011-10-25 Stmicroelectronics, Inc. Printed media products including data files provided in multiple layers of encoded, colored dots
US7630509B2 (en) 2003-09-29 2009-12-08 Alcatel-Lucent Usa Inc. Color selection scheme for digital video watermarking
CN1542689A (en) 2003-11-05 2004-11-03 深圳矽感科技有限公司 Information card having multiple storage formats and read-write apparatus and method thereof
JP4238992B2 (en) 2003-12-15 2009-03-18 富士ゼロックス株式会社 Color image processing method, color image processing apparatus, color image processing program, and storage medium
US7460278B2 (en) 2004-01-29 2008-12-02 Seiko Epson Corporation 3-Dimensional dot code for paper storage
US7471832B2 (en) 2004-02-24 2008-12-30 Trw Automotive U.S. Llc Method and apparatus for arbitrating outputs from multiple pattern recognition classifiers
US20080284793A1 (en) 2004-04-15 2008-11-20 Young Wayne D Hue and saturation control module
US7050065B1 (en) * 2004-04-15 2006-05-23 Nvidia Corporation Minimalist color space converters for optimizing image processing operations
US11049349B2 (en) 2004-06-01 2021-06-29 Daniel William Onischuk Computerized voting system
US7486802B2 (en) 2004-06-07 2009-02-03 Ford Global Technologies Llc Adaptive template object classification system with a template generator
US7119838B2 (en) 2004-08-19 2006-10-10 Blue Marlin Llc Method and imager for detecting the location of objects
CN100347714C (en) 2004-09-07 2007-11-07 佳能株式会社 Method, device and recording medium for positioning bar code
US7454086B2 (en) * 2004-09-28 2008-11-18 Ricoh Company, Ltd. Techniques for positioning images in electronic documents
KR100653886B1 (en) 2004-11-05 2006-12-05 주식회사 칼라짚미디어 Mixed-code and mixed-code encondig method and apparatus
KR100653885B1 (en) 2004-11-05 2006-12-05 주식회사 칼라짚미디어 Mixed-code decoding method and apparatus
US7751629B2 (en) 2004-11-05 2010-07-06 Colorzip Media, Inc. Method and apparatus for decoding mixed code
US7804980B2 (en) 2005-08-24 2010-09-28 Denso Corporation Environment recognition device
US20070047803A1 (en) 2005-08-30 2007-03-01 Nokia Corporation Image processing device with automatic white balance
US7711141B2 (en) 2005-08-31 2010-05-04 Sharp Laboratories Of America, Inc. Systems and methods for imaging streaming image data comprising multiple images on an image-by-image basis
JP4544109B2 (en) 2005-09-16 2010-09-15 富士ゼロックス株式会社 Image processing apparatus and program
JP4106377B2 (en) 2005-12-16 2008-06-25 インターナショナル・ビジネス・マシーンズ・コーポレーション Apparatus, method, and program for extracting invisible information
US7649650B2 (en) 2005-12-22 2010-01-19 Xerox Corporation Matching the perception of a digital image data file to a legacy hardcopy
US8243340B2 (en) 2006-02-23 2012-08-14 Microsoft Corporation Pre-processing of image data for enhanced compression
KR100678101B1 (en) * 2006-03-28 2007-02-02 삼성전자주식회사 Method for menu screen constructing display hue using picture color information of mobile terminal thereof
JP4781892B2 (en) 2006-04-19 2011-09-28 A・Tコミュニケーションズ株式会社 Two-dimensional code with logo
KR101081227B1 (en) 2006-12-21 2011-11-07 인터내셔널 비지네스 머신즈 코포레이션 Method for acquiring simulation parameter in invisible code printing support system and its system
US8905313B2 (en) 2007-04-12 2014-12-09 Honeywell International Inc. Method and system for creating and reading multi-color co-planar emissive indicia using printable dyes and pigments
US7755671B2 (en) 2007-04-23 2010-07-13 Hewlett-Packard Development Company, L.P. Correcting a captured image in digital imaging devices
CA2585956A1 (en) * 2007-04-23 2008-10-23 Spin Master Ltd. Game card, game card system, game card reader and method of authentication and fraud prevention
US8405780B1 (en) 2007-08-22 2013-03-26 Adobe Systems Incorporated Generating a clean reference image
JP5312807B2 (en) 2008-01-08 2013-10-09 オリンパス株式会社 Image processing apparatus and image processing program
US8593476B2 (en) 2008-02-13 2013-11-26 Gary Demos System for accurately and precisely representing image color information
CA2719793C (en) 2008-04-02 2014-10-07 Sicpa Holding Sa Identification and authentication using liquid crystal material markings
US8333655B2 (en) 2008-07-11 2012-12-18 Wms Gaming Inc. Methods of receiving electronic wagers in a wagering game via a handheld electronic wager input device
US8120679B2 (en) 2008-08-01 2012-02-21 Nikon Corporation Image processing method
KR20100018364A (en) 2008-08-06 2010-02-17 삼성전자주식회사 Scanning apparatus, host apparatus and scan image processing method thereof
WO2010018136A1 (en) 2008-08-12 2010-02-18 Istituto Di Ricerche Di Biologia Molecolare P. Angeletti S.P.A. Minigene comprising htpa signal peptide, t-cell epitopes, e. coli ltb and furin sensitive linkers
US8118226B2 (en) 2009-02-11 2012-02-21 Datalogic Scanning, Inc. High-resolution optical code imaging using a color imager
US8325385B2 (en) 2009-03-27 2012-12-04 Konica Minolta Laboratory U.S.A., Inc. System and methods for processing color data in converting color data from one color space to another color space
WO2010132237A1 (en) 2009-05-11 2010-11-18 Dolby Laboratories Licensing Corporation Light detection, color appearance models, and modifying dynamic range for image display
CN101964873B (en) 2009-07-21 2014-08-20 株式会社尼康 Image processing device, image processing program, and imaging device
US8819172B2 (en) 2010-11-04 2014-08-26 Digimarc Corporation Smartphone-based methods and systems
US8499148B2 (en) 2009-11-02 2013-07-30 Chi Eng System and method for virtual team collaboration in a secure environment
US8261988B2 (en) 2009-11-30 2012-09-11 Xerox Corporation Phase locked IR encoding for peened 2D barcodes
US8450704B2 (en) 2009-12-04 2013-05-28 Massachusetts Institute Of Technology Phonon-enhanced crystal growth and lattice healing
US8847972B2 (en) 2010-01-20 2014-09-30 Intellectual Ventures Fund 83 Llc Adapting display color for low luminance conditions
US8215565B2 (en) 2010-03-28 2012-07-10 Christopher Brett Howard Apparatus and method for securement of two-dimensional bar codes with geometric symbology
JP5646263B2 (en) 2010-09-27 2014-12-24 任天堂株式会社 Image processing program, image processing apparatus, image processing system, and image processing method
JP2012141729A (en) 2010-12-28 2012-07-26 Jvc Kenwood Corp Authenticity determination method, authenticity determination device, authenticity determination system, and color two-dimentional code
JP5671349B2 (en) 2011-01-06 2015-02-18 任天堂株式会社 Image processing program, image processing apparatus, image processing system, and image processing method
US8079525B1 (en) * 2011-02-24 2011-12-20 Psion Inc. System and method for decoding barcodes captured with a color image sensor
US8584953B2 (en) * 2011-02-24 2013-11-19 Psion, Inc. System and method for decoding barcodes not easily perceptible by human vision
JP2012181591A (en) 2011-02-28 2012-09-20 Jvc Kenwood Corp Identification medium, method for molding identification medium, and method for reading identification medium
US9036042B2 (en) 2011-04-15 2015-05-19 Dolby Laboratories Licensing Corporation Encoding, decoding, and representing high dynamic range images
CA2851809A1 (en) 2011-07-25 2013-01-31 4Gqr Llc Device and its use for creation, output and management of 2d barcodes with embedded images
US9449578B2 (en) 2011-09-21 2016-09-20 Stmicroelectronics (Grenoble 2) Sas Circuitry for image processing
US9111186B2 (en) 2011-10-12 2015-08-18 University Of Rochester Color barcodes for mobile applications: a per channel framework
US8879832B2 (en) 2012-06-26 2014-11-04 Xerox Corporation Color matrix code
US20140027516A1 (en) 2012-07-24 2014-01-30 Ikko Fushiki Color Extension of Barcodes
US9014469B2 (en) 2012-11-01 2015-04-21 Yael Zimet-Rubner Color-mapping wand
US9230326B1 (en) 2012-12-31 2016-01-05 Cognex Corporation System, method and calibration plate employing embedded 2D data codes as self-positioning fiducials
US9691163B2 (en) * 2013-01-07 2017-06-27 Wexenergy Innovations Llc System and method of measuring distances related to an object utilizing ancillary objects
US9042663B2 (en) 2013-03-15 2015-05-26 Pictech Management Limited Two-level error correcting codes for color space encoded image
WO2014140893A2 (en) 2013-03-15 2014-09-18 Mesh-Iliescu Alisa Documents and data backup using color space encoded image
US9591187B2 (en) * 2013-04-29 2017-03-07 Hewlett-Packard Development Company, L.P. Image processing that includes reducing a number of colors within a cell of an image
WO2014187474A1 (en) 2013-05-21 2014-11-27 Sicpa Holding Sa Identifying one- or two-dimensional bar codes via weighted image data combination
WO2014209373A1 (en) 2013-06-28 2014-12-31 Schneider Electric Usa Inc. Systems and methods of blending machine-readable and human-readable elements on a display
US20150104184A1 (en) 2013-09-16 2015-04-16 Clutch Authentication Systems, Llc System and method for communication over color encoded light patterns
US8836716B1 (en) 2013-09-20 2014-09-16 Spinella Ip Holdings, Inc. System and method for reducing visible artifacts in the display of compressed and decompressed digital images and video
US10235726B2 (en) 2013-09-24 2019-03-19 GeoFrenzy, Inc. Systems and methods for secure encryption of real estate titles and permissions
KR102241706B1 (en) 2013-11-13 2021-04-19 엘지전자 주식회사 3 dimensional camera and method for controlling the same
KR101445502B1 (en) 2013-12-09 2014-09-29 주식회사트레디오 Apparatus for detecting 2d code
WO2015130793A1 (en) 2014-02-25 2015-09-03 Apple Inc. Backward-compatible apparatus and method for providing video with both standard and high dynamic range
JP6546605B2 (en) 2014-04-15 2019-07-17 ガウス サージカル, インコーポレイテッドGauss Surgical, Inc. Method of estimating blood component amount in liquid canister
US20170238692A1 (en) * 2014-08-04 2017-08-24 Sarubbo Davide A system for checking a correct oral hygiene procedure
US20160062612A1 (en) 2014-08-29 2016-03-03 EXEYES Technologies Pvt., Ltd. Information Access Technique
CN105960802B (en) 2014-10-08 2018-02-06 微软技术许可有限责任公司 Adjustment when switching color space to coding and decoding
US10043120B2 (en) 2014-10-27 2018-08-07 Moon Key Lee Translucent mark, method for synthesis and detection of translucent mark, transparent mark, and method for synthesis and detection of transparent mark
US9552542B2 (en) * 2014-11-20 2017-01-24 International Business Machines Corporation Encoding information in multiple patterned layers
KR101995744B1 (en) 2014-11-25 2019-07-03 삼성전자주식회사 Modulation of display imagery for barcode simulation
GB2533109B (en) 2014-12-09 2018-11-28 Gurulogic Microsystems Oy Encoder, decoder and method for data
WO2016111823A2 (en) 2014-12-19 2016-07-14 Clutch Authentication Systems, Llc System and method for communication over color encoded light patterns
MX2017007938A (en) 2015-02-19 2018-01-18 Troy Group Inc Covert secure document registration system.
US10318781B2 (en) 2015-03-30 2019-06-11 Temptime Corporation Two dimensional barcode with dynamic environmental data system, method, and apparatus
KR101573655B1 (en) 2015-04-03 2015-12-03 (주)인스타페이 Method, system and recording medium for providing information using image code
DE102015106081A1 (en) 2015-04-21 2016-10-27 Friedrich Kisters Method for identifying a security pattern via an artificial 3-D reconstruction
WO2016187124A1 (en) 2015-05-17 2016-11-24 Endochoice, Inc. Endoscopic image enhancement using contrast limited adaptive histogram equalization (clahe) implemented in a processor
US10089508B2 (en) 2015-05-28 2018-10-02 Graphiclead LLC System and method of embedding a two dimensional code with concealed secure message
CN104899630B (en) 2015-06-18 2018-04-27 桂林电子科技大学 The coding/decoding method of colored QR codes
US20160379031A1 (en) * 2015-06-23 2016-12-29 Konica Minolta Laboratory U.S.A., Inc. High capacity 2d color barcode design and processing method for camera based applications
US9454688B1 (en) 2015-07-20 2016-09-27 Konica Minolta Laboratory U.S.A., Inc. High capacity 2D color barcode design and decoding method
EP3136392A1 (en) * 2015-08-25 2017-03-01 Thomson Licensing Method and system for embedding and retrieving information through marker transformation
US10467496B2 (en) * 2015-08-31 2019-11-05 Apple Inc. Temporal filtering of independent color channels in image data
US10269095B2 (en) 2015-08-31 2019-04-23 Apple Inc. Dynamically determining filtering strength for noise filtering in image processing
CN106529633B (en) * 2015-09-10 2019-11-15 阿里巴巴集团控股有限公司 Generation method, coding/decoding method and the device of two dimensional code
US10152663B2 (en) 2015-09-11 2018-12-11 Graphiclead LLC Method to store a secret QR code into a colored secure QR code
KR101773446B1 (en) 2015-09-30 2017-08-31 국민대학교산학협력단 Generation and recognition method of color qr code and system including the same
US9483718B1 (en) * 2015-12-14 2016-11-01 International Business Machines Corporation Encoding and decoding data in two-dimensional symbology
JP2017117455A (en) 2015-12-17 2017-06-29 株式会社テララコード研究所 Optical code, creation method of optical code, reading method of optical code, and barcode reading device
TWI571803B (en) 2015-12-28 2017-02-21 元智大學 Generation? method? of? color? qr? code
US10049607B2 (en) 2016-02-05 2018-08-14 Intel Corporation Color space conversion logic having reduced conversion error
US9805296B2 (en) 2016-02-23 2017-10-31 The Chinese University Of Hong Kong Method and apparatus for decoding or generating multi-layer color QR code, method for recommending setting parameters in generation of multi-layer QR code, and product comprising multi-layer color QR code
WO2017180841A1 (en) * 2016-04-13 2017-10-19 The Regents Of The University Of California Treatment of cerebral cavernous malformations
US10460141B2 (en) 2016-05-31 2019-10-29 University Of Rochester Per-channel color barcodes for displays
EP3252680B1 (en) 2016-05-31 2019-12-25 Agfa Nv Authentication method of a two dimensional bar code
US10747977B2 (en) * 2016-06-06 2020-08-18 Symbol Technologies, Llc Imaging reader for, and method of, reading symbol and non-symbol targets with color image processing pipeline having bypassable components
WO2018002944A1 (en) 2016-07-01 2018-01-04 Hewlett-Packard Development Company, L.P. Converting binary data to images
US10360651B1 (en) 2016-09-14 2019-07-23 Inscape Data, Inc. Compatible adaptive video watermarking
CN206097730U (en) 2016-09-26 2017-04-12 广东顺德锦美智能识别科技股份有限公司 Anti -counterfeit labels
CN106447590B (en) 2016-10-11 2019-08-30 华南理工大学 The addition and extracting method of digital picture watermark
EP3555811A2 (en) 2016-12-16 2019-10-23 OVD Kinegram AG Verification of a security document
US10185857B2 (en) 2017-06-14 2019-01-22 Canon Information And Imaging Solutions, Inc. Devices, systems, and methods for reading barcodes
US10699147B2 (en) * 2017-06-22 2020-06-30 BITO Robotics, Inc. Systems and methods for fast identification and processing of an image area of interest
CN111247529A (en) * 2017-08-31 2020-06-05 绳线解决方案有限公司 Color detection algorithm
US10643306B2 (en) 2017-10-11 2020-05-05 Qualcomm Incoporated Image signal processor for processing images
WO2019079806A1 (en) 2017-10-20 2019-04-25 Google Llc Content display property management
JP2019096072A (en) 2017-11-22 2019-06-20 株式会社東芝 Object detection device, object detection method and program
WO2019118097A1 (en) 2017-12-14 2019-06-20 Interdigital Vc Holdings, Inc. Method and apparatus for encoding a picture block
US20190295712A1 (en) 2018-03-20 2019-09-26 3M Innovative Properties Company Optically active article identification system
US10496909B1 (en) 2018-06-14 2019-12-03 T-Mobile Usa, Inc. Laser light detection and barcode display at mobile phone
US11113819B2 (en) 2019-01-15 2021-09-07 Nvidia Corporation Graphical fiducial marker identification suitable for augmented reality, virtual reality, and robotics
US10534948B1 (en) * 2019-03-18 2020-01-14 Capital One Services, Llc Optimizing detection of images in relation to targets based on colorspace transformation techniques
US10496911B1 (en) * 2019-03-18 2019-12-03 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet and infrared light
US10496862B1 (en) 2019-03-18 2019-12-03 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet light
US10509991B1 (en) 2019-03-18 2019-12-17 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing infrared light
US10523420B1 (en) 2019-04-18 2019-12-31 Capital One Services, Llc Transmitting encoded data along transmission mediums based on colorspace schemes
US10504013B1 (en) 2019-04-24 2019-12-10 Capital One Services, Llc Colorspace encoding multimedia data on a physical page
US10529300B1 (en) * 2019-06-20 2020-01-07 Capital One Services, Llc Adaptive image display based on colorspace conversions
US10614635B1 (en) * 2019-07-25 2020-04-07 Capital One Services, Llc Augmented reality system with color-based fiducial marker
US11049286B2 (en) 2019-07-31 2021-06-29 Hewlett Packard Enterprise Development Lp Deep neural network color space optimization
US10833852B1 (en) 2019-10-03 2020-11-10 Capital One Services, Llc Encoded data along tape based on colorspace schemes
US10715183B1 (en) 2019-10-25 2020-07-14 Capital One Services, Llc Data encoding with error-correcting code pursuant to colorspace schemes
US11023791B2 (en) 2019-10-30 2021-06-01 Kyocera Document Solutions Inc. Color conversion using neural networks
US10867226B1 (en) 2019-11-04 2020-12-15 Capital One Services, Llc Programmable logic array and colorspace conversions
US10762371B1 (en) 2019-11-14 2020-09-01 Capital One Services, Llc Object detection techniques using colorspace conversions
CA3157994A1 (en) 2019-11-27 2021-06-03 Pavel SINHA Systems and methods for performing direct conversion of image sensor data to image analytics
US10944914B1 (en) 2019-12-02 2021-03-09 Samsung Electronics Co., Ltd. System and method for generating multi-exposure frames from single input
US10878600B1 (en) 2019-12-10 2020-12-29 Capital One Services, Llc Augmented reality system with color-based fiducial marker utilizing local adaptive technology
US11526325B2 (en) 2019-12-27 2022-12-13 Abalta Technologies, Inc. Projection, control, and management of user device applications using a connected resource
US11842472B2 (en) 2020-03-31 2023-12-12 International Business Machines Corporation Object defect correction

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11314958B2 (en) 2019-03-18 2022-04-26 Capital One Services, LLC. Detecting in an environment a matrix having a least prevalent color
US10977535B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing infrared light
US10977462B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet light
US10977536B2 (en) 2019-03-18 2021-04-13 Capital One Services, Llc Detection of images in relation to targets based on colorspace transformation techniques and utilizing ultraviolet and infrared light
US11184150B2 (en) 2019-04-18 2021-11-23 Capital One Services, Llc Transmitting encoded data along transmission mediums based on colorspace schemes
US11003968B2 (en) 2019-04-24 2021-05-11 Capital One Services, Llc Colorspace encoding multimedia data on a physical page
US11024256B2 (en) * 2019-06-20 2021-06-01 Capital One Services, Llc Adaptive image display based on colorspace conversions
US11200751B2 (en) 2019-07-25 2021-12-14 Capital One Services, Llc Augmented reality system with color-based fiducial marker
EP4042221A4 (en) * 2019-10-02 2023-11-15 ChemImage Corporation Fusion of molecular chemical imaging with rgb imaging
US11342943B2 (en) 2019-10-25 2022-05-24 Capital One Services, Llc Data encoding with error-correcting code pursuant to colorspace schemes
US10867226B1 (en) 2019-11-04 2020-12-15 Capital One Services, Llc Programmable logic array and colorspace conversions
US11417075B2 (en) 2019-11-14 2022-08-16 Capital One Services, Llc Object detection techniques using colorspace conversions
US10878600B1 (en) 2019-12-10 2020-12-29 Capital One Services, Llc Augmented reality system with color-based fiducial marker utilizing local adaptive technology
US11302036B2 (en) 2020-08-19 2022-04-12 Capital One Services, Llc Color conversion between color spaces using reduced dimension embeddings

Also Published As

Publication number Publication date
CN116823971A (en) 2023-09-29
GB202214403D0 (en) 2022-11-16
US20230214626A1 (en) 2023-07-06
US11954545B2 (en) 2024-04-09
GB2608346A (en) 2022-12-28
GB2608346B (en) 2024-01-24
KR20210137103A (en) 2021-11-17
US10796122B1 (en) 2020-10-06
CN113853615B (en) 2023-07-07
GB2620512B (en) 2024-04-10
US11314958B2 (en) 2022-04-26
GB202114127D0 (en) 2021-11-17
JP7454588B2 (en) 2024-03-22
JP2024038393A (en) 2024-03-19
WO2020190789A1 (en) 2020-09-24
GB2596947B (en) 2022-11-16
US20220222460A1 (en) 2022-07-14
GB2596947A (en) 2022-01-12
US11630968B2 (en) 2023-04-18
CN113853615A (en) 2021-12-28
CA3130865A1 (en) 2020-09-24
CA3130865C (en) 2023-07-25
US20200401776A1 (en) 2020-12-24
US20240232563A1 (en) 2024-07-11
GB2620512A (en) 2024-01-10
DE112020001345T5 (en) 2022-01-13
JP2022519920A (en) 2022-03-25
US10534948B1 (en) 2020-01-14

Similar Documents

Publication Publication Date Title
US11630968B2 (en) Matrix barcode having a plurality of colors and a least prevalent color
US11720776B2 (en) System and method using a histogram and colorspaces to create a matrix barcode having a plurality of colors, an infrared layer, and an ultraviolet layer
US11798194B2 (en) System and method using a histogram and colorspaces to generate a matrix barcode having a plurality of colors and an infrared layer
US11799484B2 (en) System and method using a histogram and colorspaces to generate a matrix barcode having a plurality of colors and an ultraviolet layer
US11024256B2 (en) Adaptive image display based on colorspace conversions
US11417075B2 (en) Object detection techniques using colorspace conversions
US11816807B2 (en) Augmented reality system with color-based fiducial marker

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: CAPITAL ONE SERVICES, LLC, VIRGINIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WALTERS, AUSTIN GRANT;GOODSITT, JEREMY EDWARD;ABDI TAGHI ABAD, FARDIN;REEL/FRAME:051098/0735

Effective date: 20190318

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4