US20060062428A1 - Hierarchical watermark detector - Google Patents
Hierarchical watermark detector Download PDFInfo
- Publication number
- US20060062428A1 US20060062428A1 US11/228,033 US22803305A US2006062428A1 US 20060062428 A1 US20060062428 A1 US 20060062428A1 US 22803305 A US22803305 A US 22803305A US 2006062428 A1 US2006062428 A1 US 2006062428A1
- Authority
- US
- United States
- Prior art keywords
- watermark
- detector
- blocks
- hierarchical
- image
- 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
Links
- 238000000034 method Methods 0.000 claims abstract description 36
- 238000001514 detection method Methods 0.000 claims abstract description 26
- 238000012545 processing Methods 0.000 claims description 20
- 230000009466 transformation Effects 0.000 claims 1
- 230000008569 process Effects 0.000 description 13
- 229920001690 polydopamine Polymers 0.000 description 10
- 230000001413 cellular effect Effects 0.000 description 9
- 238000013459 approach Methods 0.000 description 7
- 238000010586 diagram Methods 0.000 description 7
- 235000019800 disodium phosphate Nutrition 0.000 description 7
- 238000003384 imaging method Methods 0.000 description 4
- 230000003247 decreasing effect Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 239000000284 extract Substances 0.000 description 2
- 230000000135 prohibitive effect Effects 0.000 description 2
- 230000009467 reduction Effects 0.000 description 2
- 230000006978 adaptation Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 125000004122 cyclic group Chemical group 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000007613 environmental effect Effects 0.000 description 1
- 238000002474 experimental method Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000011897 real-time detection Methods 0.000 description 1
- 238000010845 search algorithm Methods 0.000 description 1
- 230000005236 sound signal Effects 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000009897 systematic effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/0021—Image watermarking
- G06T1/005—Robust watermarking, e.g. average attack or collusion attack resistant
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V20/00—Scenes; Scene-specific elements
- G06V20/40—Scenes; Scene-specific elements in video content
- G06V20/46—Extracting features or characteristics from the video content, e.g. video fingerprints, representative shots or key frames
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/32—Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
- H04N1/32101—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
- H04N1/32144—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title embedded in the image data, i.e. enclosed or integrated in the image, e.g. watermark, super-imposed logo or stamp
- H04N1/32149—Methods relating to embedding, encoding, decoding, detection or retrieval operations
- H04N1/32203—Spatial or amplitude domain methods
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/32—Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
- H04N1/32101—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
- H04N1/32144—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title embedded in the image data, i.e. enclosed or integrated in the image, e.g. watermark, super-imposed logo or stamp
- H04N1/32149—Methods relating to embedding, encoding, decoding, detection or retrieval operations
- H04N1/32267—Methods relating to embedding, encoding, decoding, detection or retrieval operations combined with processing of the image
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/32—Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
- H04N1/32101—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
- H04N1/32144—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title embedded in the image data, i.e. enclosed or integrated in the image, e.g. watermark, super-imposed logo or stamp
- H04N1/32149—Methods relating to embedding, encoding, decoding, detection or retrieval operations
- H04N1/32288—Multiple embedding, e.g. cocktail embedding, or redundant embedding, e.g. repeating the additional information at a plurality of locations in the image
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/32—Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
- H04N1/32101—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
- H04N1/32144—Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title embedded in the image data, i.e. enclosed or integrated in the image, e.g. watermark, super-imposed logo or stamp
- H04N1/32352—Controlling detectability or arrangements to facilitate detection or retrieval of the embedded information, e.g. using markers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2201/00—General purpose image data processing
- G06T2201/005—Image watermarking
- G06T2201/0051—Embedding of the watermark in the spatial domain
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2201/00—General purpose image data processing
- G06T2201/005—Image watermarking
- G06T2201/0061—Embedding of the watermark in each block of the image, e.g. segmented watermarking
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2201/00—General purpose image data processing
- G06T2201/005—Image watermarking
- G06T2201/0065—Extraction of an embedded watermark; Reliable detection
Definitions
- the invention relates to digital watermarking, and specifically relates to methods for digital watermark detection and reading.
- Digital watermarking is a process for modifying physical or electronic media to embed a hidden machine-readable code into the media.
- the media may be modified such that the embedded code is imperceptible or nearly imperceptible to the user, yet may be detected through an automated detection process.
- digital watermarking is applied to media signals such as images, audio signals, and video signals.
- media signals such as images, audio signals, and video signals.
- it may also be applied to other types of media objects, including documents (e.g., through line, word or character shifting), software, multi-dimensional graphics models, and surface textures of objects.
- Digital watermarking systems typically have two primary components: an encoder that embeds the watermark in a host media signal, and a decoder that detects and reads the embedded watermark from a signal suspected of containing a watermark (a suspect signal).
- the encoder embeds a watermark by subtly altering the host media signal.
- the reading component analyzes a suspect signal to detect whether a watermark is present. In applications where the watermark encodes information, the reader extracts this information from the detected watermark.
- Integrating a hardware watermark reader in imaging devices may soon be necessary.
- imaging devices cameras, scanners, printers, fax machines, copiers
- DRM digital rights management
- An integrated watermark reader not only would enforce DRM in these devices, but also it would enable new applications. Such applications may potentially change the usage habit and pattern of these devices.
- the imaging device integrated in most of these devices could be used with a watermarked advertisement and a built-in global positioning system (GPS) to guide the user to the nearest store where the advertised goods are currently available or on sale.
- GPS global positioning system
- cellular phones and PDA devices employ fixed-point processors such as Intel's StrongARM or XScale processors, which have a clock speed in the 100-400 MHz range. This speed is only a fraction of the speed of mainstream processors typically found in PCs. This speed limits the amount of computations and their precision, which the watermark detector is allowed to perform.
- fixed-point processors such as Intel's StrongARM or XScale processors, which have a clock speed in the 100-400 MHz range. This speed is only a fraction of the speed of mainstream processors typically found in PCs. This speed limits the amount of computations and their precision, which the watermark detector is allowed to perform.
- these devices use either a primitive native operating system such as MS SmartPhone, Symbian, and Brew, or a Java-based operating system such as Doja or J2ME.
- native operating systems allow the execution of a watermark detector written in a compiled language such as C
- Java-based operating systems require Java implementations of the detector. Such an implementation is not as efficient as a C implementation, especially for sophisticated signal processing algorithms such as watermark detectors.
- a watermark detector can be implemented in a customized chip, the cost of implementing a complex algorithm can be prohibitive.
- a field programmable gate array (FPGA) or application-specific integrated circuit (ASIC) can be used for this purpose.
- FPGA field programmable gate array
- ASIC application-specific integrated circuit
- Such a chip can be integrated with the cellular phone, PDA device, or stand-alone watermark reader.
- complex watermarking algorithms may require a large number of gates and excessive on-chip memory and system bandwidth, which tremendously increases the cost of this dedicated chip. This cost, however, can be reduced substantially by reducing the data that the watermark detector operates on and the computations it performs on this data.
- This document describes a block-based watermark detector and reader that use a hierarchical search strategy to quickly zoom into the image region with the strongest watermark.
- This approach reduces the computations and the amount of data the detector operates on, which, in turn, reduces the processor speed, the memory, and the bandwidth requirement of the detector.
- This design makes the detector suitable for the aforementioned real-time software and low-cost hardware implementations.
- FIG. 1 is a block diagram illustrating a detector system.
- FIG. 2 is a flow diagram illustrating the operation of the detector system using a hierarchical search strategy.
- FIG. 3 is a flow diagram illustrating detector processing for blocks of an incoming signal in a hierarchical search strategy.
- FIG. 4 illustrates a watermark detector process for re-evaluating a portion of signal if a successful watermark decode is not achieved for blocks in that portion.
- FIG. 5 is a diagram illustrating a portion of image data, called a strip, and a pattern of blocks that are evaluated in a hierarchical watermark search strategy.
- FIG. 6 depicts a three-step log search strategy in which the search is achieved in layers.
- FIG. 7 illustrates an example of a queue used to accumulate partial watermark decoding results during a watermark search through blocks of a suspect signal.
- FIGS. 8 and 9 illustrate alternative search patterns in a watermark search strategy.
- the developed detector is suitable for devices such as stand-alone watermark readers, cellular phones, music or video players, PDAs, image processing equipment (like cameras, scanners, fax machines, copiers, printers and multifunction devices), etc. These devices have primitive operating systems with limited processing power, memory, and system bandwidth.
- Our embedder tiles the watermark over the host image to let the watermark be detected from any region in the digital or printed watermarked image as the data is streamed through the device. It also adapts the watermark strength locally to maximize detection and minimize watermark visibility. Consequently, the watermark may be detectable only in few regions of the image that are not necessarily aligned with the original tile boundaries.
- our detector uses a hierarchical search algorithm to quickly zoom into the region with the strongest watermark. This approach permits a real-time software implementation of the detector and reduces the necessary gate count, on-chip memory, and system bandwidth for a hardware implementation. Software simulation results of the developed algorithm indicate that the algorithm is very efficient and the detection results are very comparable to those obtained using the brute-force search.
- One embodiment of our embedder uses an embedding scheme that tiles the watermark over the host image. This distribution lets the watermark be detected from a small region in the digital or printed watermarked image.
- a preferred embedder embeds in each of these tiles (128 ⁇ 128 pixels) a watermark signal that carries a payload and a reference signal (or orientation component) that is used for synchronization.
- the watermark signal is preferably the same in all the tiles, and we use, e.g., a 70-bit payload. Of course, a different sized payload can be used as well.
- the reference signal can include, e.g., characteristics in an FFT or other domain, which the watermark reader uses to determine the image's original origin, scale, and orientation after the image is cropped, scaled, or rotated. Hence, this reference signal adds resiliency to the watermark against image cropping, scaling, and rotation.
- our watermark embedder may adapt watermark strength according to the local characteristics of the host image and the properties of the human vision system. See, for example, A. Reed and E. Rogers, “Color Image Appearance Model Applied to Printing of Watermarked Images”, Proc. of the ICASSP, pp 89-92, Montreal, Canada, May 2004, which is hereby incorporated by reference.
- This adaptation causes variability in the watermark strength within each tile and from one tile to another. Consequently, the regions with the strongest watermark may not necessarily be aligned with the original tile boundaries.
- the embedder may reduce the strength of the watermark to the point that the watermark becomes detectable only in a few regions.
- a watermark reference signal is detected in, e.g., the FFT domain and is used to determine a rotation angle and shift and scale factors of an input image (or video) region. This determination can be achieved by comparing a detected signal with the reference signal. A log-polar mapping and a match filter are used to perform the comparison efficiently.
- the watermarked reader uses the determined angle and scale factors to normalize the input image region, such that its orientation and size matches those of the corresponding region in the image when the image was embedded. Once the orientation and the size of the input region are normalized, the watermark reader can read the watermark from any tile within the input region where the watermark signal is strong.
- the location of this tile can be arbitrary and does not have to be aligned with the original tile when the image was embedded.
- the reader uses the shift factor to locate the origin of the watermark; it then can exploit the cyclic nature of the watermark tiles.
- a correlation detector is used to detect the watermark signal. Even more information on detector and reader implementations is provided in U.S. Pat. No. 6,614,914.
- a soft convolutional decoder is used to decode the payload. The correlation strengths of all the watermark bits are used as weights for the soft decoding. We refer to these weights in the rest of this paper as the watermark signature.
- a brute-force search can be used by the detector to detect an area in the image that contains a strong watermark.
- the detector starts by evaluating the presence of the watermark in a tile-sized region starting from the upper left corner of the input image region. If the detector does not detect a watermark, it continues by systematically shifting the location of the region to be evaluated horizontally and vertically by a small distance until the watermark is found. Since the strength of the watermark signal varies across the watermarked image, the size of the vertical and horizontal shifts must be small to achieve the desired robustness levels, which, in turn makes the search space extremely large. In this case, the detection is computationally intensive and is prohibitive for some software or stand-alone hardware implementations. For software, the brute-force detection is slow, and for hardware it is expensive, since it usually requires high gate count, memory, and system bandwidth.
- FIG. 1 is a block diagram illustrating a detector system. As shown in FIG. 1 , the detector 104 operates on image data that is acquired sequentially line-by-line, e.g., lines 100 (or data “strips”) and collected in a buffer 102 . The detector includes modules for detecting the digital watermark, and for reading a digital data message or payload carried in the detected digital watermark.
- FIG. 2 is a flow diagram illustrating the operation of the watermark detector 104 using a hierarchical search strategy.
- the detector decides whether to start processing the next line of blocks ( 114 , 116 ) or to zoom into the neighborhood of one of the processed blocks in the current strip ( 118 ).
- the blocks in any line may overlap each other as depicted in FIG. 5 .
- the data strips may also overlap each other, and the height of each strip may be more than the height of one block as illustrated. However, the amount of overlap should always be minimized to reduce the data, the computation, and the required bandwidth.
- the height of a strip may be less than a height of a block. In these cases several data strips are used to generate blocks.
- a strip height in the range of 64-320 may be suitably employed. These values were chosen empirically to maximize robustness and minimize bandwidth requirements.
- the strip values may be increased or decreased if the block size is respectfully increased (e.g., 256 ⁇ 256 blocks) or decreased (e.g., 32 ⁇ 32 blocks).
- FIG. 3 is a flow diagram illustrating detector processing for each block.
- the watermark detector attempts to detect the reference signal ( 120 ) and determine the orientation angle and the scale and shift factors ( 122 ). If it finds the reference signal in any block with a high confidence ( 124 ), then the detector attempts to read the watermark signal and decode the payload ( 126 ). It uses the correlation value obtained from a match filter used in the process of detecting the reference signal as an indicator of watermark presence and strength. If the detector decodes the payload successfully ( 128 ), it terminates the process and exits ( 130 ); otherwise, it moves on to the next block in the current strip. If the reader attempts to read the watermark and fails, the detector preferably saves the resulting watermark signature in a queue that can be used for boosting the signal that could be found in subsequent blocks ( 132 ).
- FIG. 4 illustrates a process for evaluating a strip if a successful decode is not achieved for that strip. If the watermark detector was not successful in decoding the payload in any of the blocks in a strip, it again assesses the watermark strengths of all the blocks in the strip ( 140 , 142 ). If the watermark strength in any one of these blocks is sufficiently high ( 144 ), it zooms into the area of that block ( 146 ). (Sufficiency can be determined before hand based on accepted tolerances relative to, e.g., processing time or acceptable false positive/false negative decode rates.) Then, the detector performs a fast and systematic search for the watermark in a neighborhood of the best block. Otherwise, the detector proceeds to the next strip ( 148 ).
- FIG. 6 depicts a three-step log search strategy in which the search is achieved in layers.
- Each of the dots in the figure indicates a center of a 128 ⁇ 128 block.
- the number associated with each block indicates the layer it belongs to.
- the blocks in a layer with lower numbers are evaluated first.
- the blocks in each layer are evaluated clockwise starting from the upper-left corner.
- the detector does not evaluate the center block in the current layer, since it has already evaluated that block when the detector evaluated the blocks of the previous layer.
- the detector evaluates the blocks in each layer in a similar fashion to that used in evaluating the blocks in a strip.
- the detector attempts to detect the reference signal. If it finds the reference signal with a high confidence, then it attempts to read the watermark signal. If it decodes the payload successfully, it terminates the process and exits; otherwise, it moves on to the next block in the current layer. It also saves the watermark signature of any block it attempts to read. If the watermark detector was not successful in decoding the payload in any of the blocks in a layer, it again assesses the watermark strengths of all the blocks in that layer. If the watermark strength in any of these blocks is sufficiently high, it zooms into the area of the block with the highest watermark strength.
- the detector method described above tremendously reduces the amount of data the watermark detector operates on and the amount of computations it performs.
- Using brute-force search on a W ⁇ H image would require processing a maximum of W M ⁇ H N blocks, where M and N are the horizontal and vertical shifts in pixels.
- M and N are the horizontal and vertical shifts in pixels.
- the values of M and N must be small.
- the hierarchical search would require the processing of a maximum of H 128 ⁇ ( W 128 + K ⁇ L ) blocks, where L is the maximum number of layers allowed, and K is the number of block positions in the search pattern.
- L is the maximum number of layers allowed
- K is the number of block positions in the search pattern.
- the detector shares statistics about the watermark signal between blocks. These statistics include the signature, the scale factor, the rotation angle, and the shift factor.
- the signature is a sequence of 512 bits that represents the watermark in the block. Since the same watermark signal is embedded in all the blocks, a signature obtained from one block can be used to reinforce the detection in another block provided that both blocks have compatible scale factors and rotation angles.
- the detector uses the queue depicted in FIG. 7 to hold and manipulate the extracted signatures from the blocks. In our experiments, we used a queue of length equal to 9; however, this length can be adjusted according to environmental constraints.
- the detector automatically adds the signature it extracts from a block to the signature queue. Then, the detector groups all the signatures in the queue according to their associated rotation angles and scale and shift factors. The detector then adds the signatures with compatible rotation angles and scale and shift factors and attempts to decode the payload from the accumulated signature.
- the detector uses a first-in-first-out strategy to update the queue, but other strategies can also be used.
- Table 1 which lists the results, indicates that we were able to achieve a slightly higher detection rate with the hierarchical detector than with the brute-force-based detector even when the brute-force-based algorithm used horizontal and vertical shifts of 16 pixels.
- the hierarchical detector always used much less data than the brute-force-based detector.
- the hierarchical detector was restricted to one layer, it only used 3.6% of data used by the brute-force-based detector. This reduction is not only a major savings in processing time, but also a major savings in memory and bandwidth requirements.
- Table 2 lists the results, which indicate that using any of these patterns produces a detection rate that is slightly lower than the detection rate obtained when the eight nearest neighbor search pattern was used. However, the use of either pattern saves about 29% of the computation, bandwidth, and memory.
- the hierarchical block based approach described above may be implemented on parallel detector modules.
- Each of these parallel detector modules may be implemented in software, hardware or a combination of both as described further below.
- the parallel detector modules operate on different parts of an incoming signal suspected of being watermarked.
- the detector modules obtains a successful decode, it returns the result of its decoding (e.g., a decoded message payload) and optionally instructs other detector modules to terminate processing on the incoming signal.
- the parallel detector modules can be used to optimize watermark detection processing on large numbers of different incoming suspect signals (e.g., image or audio files, frames of images captured from a camera or camera phone, audio clips, etc).
- the parallel detector system quickly analyzes different incoming signals for the presence of digital watermarks and is able to process many more signals in a shorter period of time.
- the parallel detector system quickly evaluates whether a watermark can be extracted from it by concurrently analyzing different parts of the signal.
- the system quickly identifies marked and un-marked signals, decodes payloads from marked signals, and moves on to analyze different incoming signals.
- several incoming signals can be evaluated concurrently.
- Concurrent processing of the detector can be implemented across hardware elements and software modules (e.g., concurrent software threads or processes in a multi-tasking operating system).
- a distributing computing system can be used to distribute several instances of the detector on different processors and/or threads of execution in a distributed computing system. Specific examples include distributing the detecting functions across client device and server systems. For example, a quick pass through each strip may be performed on a client device (e.g., cell phone or PDA), and the zooming in on blocks in selected neighborhoods can be performed on a server (e.g., a server on the Internet).
- the detector method described above can be implemented in software, firmware, hardware or combinations of software, firmware, and hardware.
- the detector system is implemented in an ASIC.
- it is implemented in an FPGA.
- it is implemented in a DSP.
- it is implemented in a native processor of a portable or imaging device, such as a native processor of a PDA, cell phone, camera, scanner, etc.
- it is implemented in software instructions written in a programming language like C, C++, Java, etc. and ported to a processor for a Personal Computer.
- the specific implementation depends on the application and target device in which the detector application is going to be used.
- the implementation is adapted to the existing processor or DSP in the target device.
- additional hardware such as hardware in the form of an ASIC or FPGA can be used to implement parts of the detector that cannot practically be implemented in software/firmware executing on the processor/DSP.
- One driving factor in determining what portions to implement in hardware and software/firmware is avoidance of consuming limited processing resources when trying to detect watermarks in un-marked or weakly marked signal portions.
- one approach is to implement the initial detector process on the initial layer (e.g., the search through the “strip” portion) of the multi-layer hierarchical search in special purpose hardware logic, such as in an ASIC or FPGA.
- Refinement searches on subsequent layers e.g., the zooming into blocks in neighborhoods of the second or subsequent hierarchical layers
- the detector module can be implemented on special purpose processors, like the MXP5800 from Intel to take advantage of the image processing functions and parallel processing capabilities of the processor. Similarly, vector processing available on DSPs may also be exploited to perform signal processing functions of the detector more efficiently.
- auxiliary data encoding processes may be implemented in a programmable computer or a special purpose digital circuit.
- auxiliary data decoding may be implemented in software, firmware, hardware, or combinations of software, firmware and hardware.
- the methods and processes described above may be implemented in programs executed from a system's memory (a computer readable medium, such as an electronic, optical or magnetic storage device).
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Editing Of Facsimile Originals (AREA)
- Image Processing (AREA)
Abstract
Description
- This application claims the benefit of U.S. Provisional Patent Application No. 60/610,823, filed Sep. 17, 2004. This application is also related to assignee's U.S. patent application Ser. No. 09/659,125, filed Sep. 11, 2000 (allowed); Ser. No. 10/053,488, filed Nov. 2, 2001 (published as US 2002-0120849 A1); Ser. No. 09/945,244, filed Aug. 31, 2001 (published as US 2002-0057823 A1); Ser. No. 10/686,495, filed Oct. 14, 2003 (published as US 2004-0181671 A1); and Ser. No. 10/033,363, filed Oct. 25, 2001 (published as US 2003-0081810 A1). Each of the above patent documents is hereby incorporated by reference.
- The invention relates to digital watermarking, and specifically relates to methods for digital watermark detection and reading. In one implementation, we provide a hierarchical watermark detecting method and detector apparatus.
- Digital watermarking is a process for modifying physical or electronic media to embed a hidden machine-readable code into the media. The media may be modified such that the embedded code is imperceptible or nearly imperceptible to the user, yet may be detected through an automated detection process. Most commonly, digital watermarking is applied to media signals such as images, audio signals, and video signals. However, it may also be applied to other types of media objects, including documents (e.g., through line, word or character shifting), software, multi-dimensional graphics models, and surface textures of objects.
- Digital watermarking systems typically have two primary components: an encoder that embeds the watermark in a host media signal, and a decoder that detects and reads the embedded watermark from a signal suspected of containing a watermark (a suspect signal). The encoder embeds a watermark by subtly altering the host media signal. The reading component analyzes a suspect signal to detect whether a watermark is present. In applications where the watermark encodes information, the reader extracts this information from the detected watermark.
- Several particular watermarking techniques have been developed. The reader is presumed to be familiar with the literature in this field. Particular techniques for embedding and detecting imperceptible watermarks in media signals are detailed in the assignee's U.S. Pat. Nos. 6,122,403 and 6,614,914, which are hereby incorporated by reference.
- Integrating a hardware watermark reader in imaging devices (cameras, scanners, printers, fax machines, copiers) cellular phones, PDA devices may soon be necessary. Currently, most of these devices have no digital rights management (DRM) and hence can freely download music, video, and pictures from the Internet. An integrated watermark reader not only would enforce DRM in these devices, but also it would enable new applications. Such applications may potentially change the usage habit and pattern of these devices. For example, the imaging device integrated in most of these devices could be used with a watermarked advertisement and a built-in global positioning system (GPS) to guide the user to the nearest store where the advertised goods are currently available or on sale.
- Low-cost stand-alone watermark readers will also be developed soon to harness the power of the millions of watermark-enhanced identity cards already deployed in the USA and around the world. These readers will be essential in enforcing the law and reducing identity thefts. Also, the ubiquitous deployment of these readers will enable and empower a new wave of applications.
- Cellular phones and PDA devices, however, have some limitations when used with sophisticated watermark detectors operating on large images. These limitations include the type and speed of the processor used in these devices, the amount of available memory, the system bandwidth, and the operating system controlling these devices.
- Usually, cellular phones and PDA devices employ fixed-point processors such as Intel's StrongARM or XScale processors, which have a clock speed in the 100-400 MHz range. This speed is only a fraction of the speed of mainstream processors typically found in PCs. This speed limits the amount of computations and their precision, which the watermark detector is allowed to perform.
- These devices also have limited DRAM and system bandwidth. Currently, PDA devices have 32 MB of memory, but cellular phones have about 6 MB only. About half of the memory available on cellular phones is used by the operating system. Also, most of these devices have about 20 MHz of system bandwidth. The low bandwidth combined with the lack of memory can be a major bottleneck for real-time detection of the watermarks embedded in large images via cellular phones and PDA devices.
- Moreover, these devices use either a primitive native operating system such as MS SmartPhone, Symbian, and Brew, or a Java-based operating system such as Doja or J2ME. Although native operating systems allow the execution of a watermark detector written in a compiled language such as C, Java-based operating systems require Java implementations of the detector. Such an implementation is not as efficient as a C implementation, especially for sophisticated signal processing algorithms such as watermark detectors.
- Although a watermark detector can be implemented in a customized chip, the cost of implementing a complex algorithm can be prohibitive. A field programmable gate array (FPGA) or application-specific integrated circuit (ASIC) can be used for this purpose. Such a chip can be integrated with the cellular phone, PDA device, or stand-alone watermark reader. However, complex watermarking algorithms may require a large number of gates and excessive on-chip memory and system bandwidth, which tremendously increases the cost of this dedicated chip. This cost, however, can be reduced substantially by reducing the data that the watermark detector operates on and the computations it performs on this data.
- This document describes a block-based watermark detector and reader that use a hierarchical search strategy to quickly zoom into the image region with the strongest watermark. This approach reduces the computations and the amount of data the detector operates on, which, in turn, reduces the processor speed, the memory, and the bandwidth requirement of the detector. This design makes the detector suitable for the aforementioned real-time software and low-cost hardware implementations.
- Further features and combinations will become even more apparent with reference to the following detailed description and accompanying drawings.
-
FIG. 1 is a block diagram illustrating a detector system. -
FIG. 2 is a flow diagram illustrating the operation of the detector system using a hierarchical search strategy. -
FIG. 3 is a flow diagram illustrating detector processing for blocks of an incoming signal in a hierarchical search strategy. -
FIG. 4 illustrates a watermark detector process for re-evaluating a portion of signal if a successful watermark decode is not achieved for blocks in that portion. -
FIG. 5 is a diagram illustrating a portion of image data, called a strip, and a pattern of blocks that are evaluated in a hierarchical watermark search strategy. -
FIG. 6 depicts a three-step log search strategy in which the search is achieved in layers. -
FIG. 7 illustrates an example of a queue used to accumulate partial watermark decoding results during a watermark search through blocks of a suspect signal. -
FIGS. 8 and 9 illustrate alternative search patterns in a watermark search strategy. - In this document, we describe a digital watermark method for real-time software or low-cost hardware implementation. The developed detector is suitable for devices such as stand-alone watermark readers, cellular phones, music or video players, PDAs, image processing equipment (like cameras, scanners, fax machines, copiers, printers and multifunction devices), etc. These devices have primitive operating systems with limited processing power, memory, and system bandwidth. Our embedder tiles the watermark over the host image to let the watermark be detected from any region in the digital or printed watermarked image as the data is streamed through the device. It also adapts the watermark strength locally to maximize detection and minimize watermark visibility. Consequently, the watermark may be detectable only in few regions of the image that are not necessarily aligned with the original tile boundaries. To avoid a brute-force search, our detector uses a hierarchical search algorithm to quickly zoom into the region with the strongest watermark. This approach permits a real-time software implementation of the detector and reduces the necessary gate count, on-chip memory, and system bandwidth for a hardware implementation. Software simulation results of the developed algorithm indicate that the algorithm is very efficient and the detection results are very comparable to those obtained using the brute-force search.
- Digital Watermark Embedder
- One embodiment of our embedder uses an embedding scheme that tiles the watermark over the host image. This distribution lets the watermark be detected from a small region in the digital or printed watermarked image. A preferred embedder embeds in each of these tiles (128×128 pixels) a watermark signal that carries a payload and a reference signal (or orientation component) that is used for synchronization. The watermark signal is preferably the same in all the tiles, and we use, e.g., a 70-bit payload. Of course, a different sized payload can be used as well. We also prefer to use spread-spectrum techniques and convolutional error correction codes to combat noise and maximize robustness. Specific methods for implementing such a watermark embedder are provided in U.S. Pat. No. 6,614,914, which is incorporated above.
- The reference signal can include, e.g., characteristics in an FFT or other domain, which the watermark reader uses to determine the image's original origin, scale, and orientation after the image is cropped, scaled, or rotated. Hence, this reference signal adds resiliency to the watermark against image cropping, scaling, and rotation.
- To maximize detection and minimize watermark visibility, our watermark embedder may adapt watermark strength according to the local characteristics of the host image and the properties of the human vision system. See, for example, A. Reed and E. Rogers, “Color Image Appearance Model Applied to Printing of Watermarked Images”, Proc. of the ICASSP, pp 89-92, Montreal, Canada, May 2004, which is hereby incorporated by reference. This adaptation, however, causes variability in the watermark strength within each tile and from one tile to another. Consequently, the regions with the strongest watermark may not necessarily be aligned with the original tile boundaries. Moreover, when visibility of the watermark is a major concern, the embedder may reduce the strength of the watermark to the point that the watermark becomes detectable only in a few regions.
- In the next section, we describe a block-based hierarchical detector, which allows real-time implementation of the detector in cellular phones, PDA devices, video and game players and imaging devices (cameras, scanners, printers, copiers, fax machines, etc). It also allows low-cost hardware implementation of the detector in stand-alone watermark readers.
- Hierarchical Watermark Detector
- During the reading process in one embodiment, a watermark reference signal is detected in, e.g., the FFT domain and is used to determine a rotation angle and shift and scale factors of an input image (or video) region. This determination can be achieved by comparing a detected signal with the reference signal. A log-polar mapping and a match filter are used to perform the comparison efficiently. The watermarked reader, then, uses the determined angle and scale factors to normalize the input image region, such that its orientation and size matches those of the corresponding region in the image when the image was embedded. Once the orientation and the size of the input region are normalized, the watermark reader can read the watermark from any tile within the input region where the watermark signal is strong. The location of this tile can be arbitrary and does not have to be aligned with the original tile when the image was embedded. To read the watermark correctly, the reader uses the shift factor to locate the origin of the watermark; it then can exploit the cyclic nature of the watermark tiles. A correlation detector is used to detect the watermark signal. Even more information on detector and reader implementations is provided in U.S. Pat. No. 6,614,914. A soft convolutional decoder is used to decode the payload. The correlation strengths of all the watermark bits are used as weights for the soft decoding. We refer to these weights in the rest of this paper as the watermark signature.
- Brute-Force Search
- A brute-force search can be used by the detector to detect an area in the image that contains a strong watermark. In this case, the detector starts by evaluating the presence of the watermark in a tile-sized region starting from the upper left corner of the input image region. If the detector does not detect a watermark, it continues by systematically shifting the location of the region to be evaluated horizontally and vertically by a small distance until the watermark is found. Since the strength of the watermark signal varies across the watermarked image, the size of the vertical and horizontal shifts must be small to achieve the desired robustness levels, which, in turn makes the search space extremely large. In this case, the detection is computationally intensive and is prohibitive for some software or stand-alone hardware implementations. For software, the brute-force detection is slow, and for hardware it is expensive, since it usually requires high gate count, memory, and system bandwidth.
- Hierarchical Search
- To avoid a brute-force search, a preferred detector uses a hierarchical search strategy to quickly zoom into the image region with a strong (or strongest) watermark.
FIG. 1 is a block diagram illustrating a detector system. As shown inFIG. 1 , thedetector 104 operates on image data that is acquired sequentially line-by-line, e.g., lines 100 (or data “strips”) and collected in abuffer 102. The detector includes modules for detecting the digital watermark, and for reading a digital data message or payload carried in the detected digital watermark. -
FIG. 2 is a flow diagram illustrating the operation of thewatermark detector 104 using a hierarchical search strategy. Once a sufficient number of data strips are acquired in the buffer (110), the data is streamed through the detector block by block (112). - Once the detector finishes processing a line of blocks, it decides whether to start processing the next line of blocks (114, 116) or to zoom into the neighborhood of one of the processed blocks in the current strip (118). The blocks in any line may overlap each other as depicted in
FIG. 5 . Similarly, the data strips may also overlap each other, and the height of each strip may be more than the height of one block as illustrated. However, the amount of overlap should always be minimized to reduce the data, the computation, and the required bandwidth. We also note that the height of a strip may be less than a height of a block. In these cases several data strips are used to generate blocks. - In one implementation, we chose to use 128×128 non-overlapping blocks and non-overlapping strips of height of 256 pixels. Of course, a strip height in the range of 64-320 may be suitably employed. These values were chosen empirically to maximize robustness and minimize bandwidth requirements. Of course, the strip values may be increased or decreased if the block size is respectfully increased (e.g., 256×256 blocks) or decreased (e.g., 32×32 blocks).
-
FIG. 3 is a flow diagram illustrating detector processing for each block. For each of the blocks in the current strip the watermark detector attempts to detect the reference signal (120) and determine the orientation angle and the scale and shift factors (122). If it finds the reference signal in any block with a high confidence (124), then the detector attempts to read the watermark signal and decode the payload (126). It uses the correlation value obtained from a match filter used in the process of detecting the reference signal as an indicator of watermark presence and strength. If the detector decodes the payload successfully (128), it terminates the process and exits (130); otherwise, it moves on to the next block in the current strip. If the reader attempts to read the watermark and fails, the detector preferably saves the resulting watermark signature in a queue that can be used for boosting the signal that could be found in subsequent blocks (132). -
FIG. 4 illustrates a process for evaluating a strip if a successful decode is not achieved for that strip. If the watermark detector was not successful in decoding the payload in any of the blocks in a strip, it again assesses the watermark strengths of all the blocks in the strip (140, 142). If the watermark strength in any one of these blocks is sufficiently high (144), it zooms into the area of that block (146). (Sufficiency can be determined before hand based on accepted tolerances relative to, e.g., processing time or acceptable false positive/false negative decode rates.) Then, the detector performs a fast and systematic search for the watermark in a neighborhood of the best block. Otherwise, the detector proceeds to the next strip (148). -
FIG. 6 depicts a three-step log search strategy in which the search is achieved in layers. Each of the dots in the figure indicates a center of a 128×128 block. The number associated with each block indicates the layer it belongs to. The blocks in a layer with lower numbers are evaluated first. The blocks in each layer are evaluated clockwise starting from the upper-left corner. The detector does not evaluate the center block in the current layer, since it has already evaluated that block when the detector evaluated the blocks of the previous layer. - The detector evaluates the blocks in each layer in a similar fashion to that used in evaluating the blocks in a strip. The detector attempts to detect the reference signal. If it finds the reference signal with a high confidence, then it attempts to read the watermark signal. If it decodes the payload successfully, it terminates the process and exits; otherwise, it moves on to the next block in the current layer. It also saves the watermark signature of any block it attempts to read. If the watermark detector was not successful in decoding the payload in any of the blocks in a layer, it again assesses the watermark strengths of all the blocks in that layer. If the watermark strength in any of these blocks is sufficiently high, it zooms into the area of the block with the highest watermark strength. In this case, it reduces the distances between the blocks in the search pattern by 50%. The iterations stop once the watermark is read or the number of iterations reaches a predefined maximum. A circle around a block location in
FIG. 6 indicates the location of the best block in that layer. - Brute-Force Search vs. Hierarchical Search
- The detector method described above tremendously reduces the amount of data the watermark detector operates on and the amount of computations it performs. Using brute-force search on a W×H image (where W is image width in pixels and H is image height in pixels) would require processing a maximum of
blocks, where M and N are the horizontal and vertical shifts in pixels. To achieve a practically good robustness level, the values of M and N must be small. For W=320, H=240, and M=N=16, the blocks are overlapped by 112 pixels in both directions, and the maximum number of blocks that would be processed by the brute-force detector is about 300 blocks. Decreasing the block overlap would reduce the number of blocks to be processed, but this reduction causes a rapid decline in the robustness of the algorithm. - On the other hand, the hierarchical search would require the processing of a maximum of
blocks, where L is the maximum number of layers allowed, and K is the number of block positions in the search pattern. For three layers and eight block positions in the search pattern, the maximum number of blocks that would be processed by the developed hierarchical approach is about 50 blocks, which is about 17% of the maximum number of blocks in the brute-force search with M=N=16, while maintaining an equivalent level of robustness.
Combining Signature - As mentioned before, to boost robustness, the detector shares statistics about the watermark signal between blocks. These statistics include the signature, the scale factor, the rotation angle, and the shift factor. In one embodiment, the signature is a sequence of 512 bits that represents the watermark in the block. Since the same watermark signal is embedded in all the blocks, a signature obtained from one block can be used to reinforce the detection in another block provided that both blocks have compatible scale factors and rotation angles. The detector uses the queue depicted in
FIG. 7 to hold and manipulate the extracted signatures from the blocks. In our experiments, we used a queue of length equal to 9; however, this length can be adjusted according to environmental constraints. - The detector automatically adds the signature it extracts from a block to the signature queue. Then, the detector groups all the signatures in the queue according to their associated rotation angles and scale and shift factors. The detector then adds the signatures with compatible rotation angles and scale and shift factors and attempts to decode the payload from the accumulated signature. The detector uses a first-in-first-out strategy to update the queue, but other strategies can also be used.
- Results
- Hierarchical Approach vs. Brute-Force Approach
- We implemented the hierarchical block-based watermarking algorithm described above and tested it with 1,250 images of various sizes, scales, and orientations. We used non-overlapping blocks in each strip, and we used the search pattern shown in
FIG. 6 to zoom into the neighborhood of the block with the strongest signal. We set the initial distance (horizontal or vertical) between any two adjacent blocks in the search pattern to 64 pixels. We varied the number of layers from one to three. We compared the results with those we obtained from the brute-force-based algorithm with various overlaps between blocks. All tested algorithms always ignored worthless (purely blank) blocks.TABLE 1 Avg. # Max Detection Algorithm Processed Blocks Rate Brute-force-based; 16 shift 2,656 99.52% Brute-force-based; 32 shift 664 98.16% Brute-force-based; 64 shift 166 94.96% Hierarchical, 1 layer, 8 nearest 96 99.92% neighbor search pattern Hierarchical, 2 layers, 8 nearest 150 99.84% neighbor search pattern Hierarchical, 3 layers, 8 nearest 204 100.00% neighbor search pattern - Table 1, which lists the results, indicates that we were able to achieve a slightly higher detection rate with the hierarchical detector than with the brute-force-based detector even when the brute-force-based algorithm used horizontal and vertical shifts of 16 pixels. The hierarchical detector always used much less data than the brute-force-based detector. When the hierarchical detector was restricted to one layer, it only used 3.6% of data used by the brute-force-based detector. This reduction is not only a major savings in processing time, but also a major savings in memory and bandwidth requirements.
- Hierarchical Patterns with Different Search Patterns
- To reduce the computational load further, we investigated the use of two alternative search patterns. These patterns are the 5 plus-shaped and the 5 cross-shaped, which are depicted in
FIGS. 8 and 9 . Using these patterns with the three-step log search described previously, the detector evaluates four blocks per layer instead of eight blocks. We tested our hierarchical detector using both patterns.TABLE 2 Avg. # Max Detection Algorithm Processed Blocks Rate Hierarchical, 3 layers, 8 nearest 204 100.00% neighbor search pattern Hierarchical, 3 layers, 5 cross- 143 99.76% shaped search pattern Hierarchical, 3 layers, 5 143 99.68% plus-shaped search pattern - Table 2 lists the results, which indicate that using any of these patterns produces a detection rate that is slightly lower than the detection rate obtained when the eight nearest neighbor search pattern was used. However, the use of either pattern saves about 29% of the computation, bandwidth, and memory.
- Parallel Search System
- The hierarchical block based approach described above may be implemented on parallel detector modules. Each of these parallel detector modules may be implemented in software, hardware or a combination of both as described further below. In one implementation, the parallel detector modules operate on different parts of an incoming signal suspected of being watermarked. When one of the detector modules obtains a successful decode, it returns the result of its decoding (e.g., a decoded message payload) and optionally instructs other detector modules to terminate processing on the incoming signal.
- In some implementations, such as a server-based parallel detector system, the parallel detector modules can be used to optimize watermark detection processing on large numbers of different incoming suspect signals (e.g., image or audio files, frames of images captured from a camera or camera phone, audio clips, etc). In this case, the parallel detector system quickly analyzes different incoming signals for the presence of digital watermarks and is able to process many more signals in a shorter period of time. For each incoming signal, the parallel detector system quickly evaluates whether a watermark can be extracted from it by concurrently analyzing different parts of the signal. The system quickly identifies marked and un-marked signals, decodes payloads from marked signals, and moves on to analyze different incoming signals. With the addition of more parallel processors, several incoming signals can be evaluated concurrently.
- Concurrent processing of the detector can be implemented across hardware elements and software modules (e.g., concurrent software threads or processes in a multi-tasking operating system). In addition, a distributing computing system can be used to distribute several instances of the detector on different processors and/or threads of execution in a distributed computing system. Specific examples include distributing the detecting functions across client device and server systems. For example, a quick pass through each strip may be performed on a client device (e.g., cell phone or PDA), and the zooming in on blocks in selected neighborhoods can be performed on a server (e.g., a server on the Internet).
- System Implementation
- The detector method described above can be implemented in software, firmware, hardware or combinations of software, firmware, and hardware. In one implementation, the detector system is implemented in an ASIC. In another, it is implemented in an FPGA. In another, it is implemented in a DSP. In another, it is implemented in a native processor of a portable or imaging device, such as a native processor of a PDA, cell phone, camera, scanner, etc. In yet another, it is implemented in software instructions written in a programming language like C, C++, Java, etc. and ported to a processor for a Personal Computer.
- The specific implementation depends on the application and target device in which the detector application is going to be used. Preferably, the implementation is adapted to the existing processor or DSP in the target device. However, if the capabilities of the processor or DSP are insufficient for the watermarking application, additional hardware, such as hardware in the form of an ASIC or FPGA can be used to implement parts of the detector that cannot practically be implemented in software/firmware executing on the processor/DSP.
- One driving factor in determining what portions to implement in hardware and software/firmware is avoidance of consuming limited processing resources when trying to detect watermarks in un-marked or weakly marked signal portions. As such, one approach is to implement the initial detector process on the initial layer (e.g., the search through the “strip” portion) of the multi-layer hierarchical search in special purpose hardware logic, such as in an ASIC or FPGA. Refinement searches on subsequent layers (e.g., the zooming into blocks in neighborhoods of the second or subsequent hierarchical layers) are implemented in software/firmware of the native processor or DSP of the target device. This enables the hardware to quickly identify parts of signals where successful watermark decoding is likely, and avoids bogging down the processor/DSP with thrashing on un-marked signals.
- The detector module, or parts of it, can be implemented on special purpose processors, like the MXP5800 from Intel to take advantage of the image processing functions and parallel processing capabilities of the processor. Similarly, vector processing available on DSPs may also be exploited to perform signal processing functions of the detector more efficiently.
- Having described and illustrated the principles of the technology with reference to specific implementations, it will be recognized that the technology can be implemented in many other, different, forms. To provide a comprehensive disclosure without unduly lengthening the specification, applicants incorporate by reference the patents and patent applications referenced above.
- The methods, processes, and systems described above may be implemented in hardware, software or a combination of hardware and software. For example, the auxiliary data encoding processes may be implemented in a programmable computer or a special purpose digital circuit. Similarly, auxiliary data decoding may be implemented in software, firmware, hardware, or combinations of software, firmware and hardware. The methods and processes described above may be implemented in programs executed from a system's memory (a computer readable medium, such as an electronic, optical or magnetic storage device).
- The particular combinations of elements and features in the above-detailed embodiments are exemplary only; the interchanging and substitution of these teachings with other teachings in this and the incorporated-by-reference patents/applications are also contemplated.
Claims (15)
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/228,033 US8891811B2 (en) | 2004-09-17 | 2005-09-14 | Hierarchical watermark detector |
US14/546,708 US9412144B2 (en) | 2004-09-17 | 2014-11-18 | Hierarchical watermark detector |
US15/232,388 US9898792B2 (en) | 2004-09-17 | 2016-08-09 | Hierarchical watermark detector |
US15/899,292 US10607311B2 (en) | 2004-09-17 | 2018-02-19 | Hierarchical watermark detector |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US61082304P | 2004-09-17 | 2004-09-17 | |
US11/228,033 US8891811B2 (en) | 2004-09-17 | 2005-09-14 | Hierarchical watermark detector |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/546,708 Continuation US9412144B2 (en) | 2004-09-17 | 2014-11-18 | Hierarchical watermark detector |
Publications (2)
Publication Number | Publication Date |
---|---|
US20060062428A1 true US20060062428A1 (en) | 2006-03-23 |
US8891811B2 US8891811B2 (en) | 2014-11-18 |
Family
ID=36074032
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/228,033 Active 2031-09-10 US8891811B2 (en) | 2004-09-17 | 2005-09-14 | Hierarchical watermark detector |
US14/546,708 Active US9412144B2 (en) | 2004-09-17 | 2014-11-18 | Hierarchical watermark detector |
US15/232,388 Active US9898792B2 (en) | 2004-09-17 | 2016-08-09 | Hierarchical watermark detector |
US15/899,292 Active US10607311B2 (en) | 2004-09-17 | 2018-02-19 | Hierarchical watermark detector |
Family Applications After (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/546,708 Active US9412144B2 (en) | 2004-09-17 | 2014-11-18 | Hierarchical watermark detector |
US15/232,388 Active US9898792B2 (en) | 2004-09-17 | 2016-08-09 | Hierarchical watermark detector |
US15/899,292 Active US10607311B2 (en) | 2004-09-17 | 2018-02-19 | Hierarchical watermark detector |
Country Status (1)
Country | Link |
---|---|
US (4) | US8891811B2 (en) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110007935A1 (en) * | 2000-04-19 | 2011-01-13 | Reed Alastair M | Digital Watermarking in Data Representing Color Channels |
US8890950B2 (en) | 2010-05-05 | 2014-11-18 | Digimarc Corporation | Methods and arrangements for processing image data |
US20150145687A1 (en) * | 2013-11-22 | 2015-05-28 | Aps Technology, Inc. | System, Apparatus, and Method for Drilling |
US9179033B2 (en) | 2000-04-19 | 2015-11-03 | Digimarc Corporation | Digital watermarking in data representing color channels |
US9959586B1 (en) * | 2016-12-13 | 2018-05-01 | GoAnimate, Inc. | System, method, and computer program for encoding and decoding a unique signature in a video file as a set of watermarks |
US11049094B2 (en) | 2014-02-11 | 2021-06-29 | Digimarc Corporation | Methods and arrangements for device to device communication |
WO2024020638A1 (en) * | 2022-07-27 | 2024-02-01 | GeoSnapshot Pty Ltd | Inspection of digital images through watermarks |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8891811B2 (en) | 2004-09-17 | 2014-11-18 | Digimarc Corporation | Hierarchical watermark detector |
EP2255315A4 (en) * | 2008-02-11 | 2013-01-23 | Secure Content Storage Ass Llc | Simple non-autonomous peering environment watermarking, authentication and binding |
US9976413B2 (en) | 2015-02-20 | 2018-05-22 | Aps Technology, Inc. | Pressure locking device for downhole tools |
US9819950B2 (en) | 2015-07-02 | 2017-11-14 | Digimarc Corporation | Hardware-adaptable watermark systems |
JP6741306B2 (en) | 2015-07-16 | 2020-08-19 | ディジマーク コーポレイション | Method, apparatus and computer readable medium for estimating geometric transformation of an image for digital data extraction |
US10853903B1 (en) * | 2016-09-26 | 2020-12-01 | Digimarc Corporation | Detection of encoded signals and icons |
CN106408503B (en) * | 2016-11-29 | 2018-09-04 | 海南大学 | The immune image digital watermark method of rights management is classified towards copyright |
US11257198B1 (en) | 2017-04-28 | 2022-02-22 | Digimarc Corporation | Detection of encoded signals and icons |
USD920287S1 (en) * | 2019-05-07 | 2021-05-25 | MBRIO Technologies LLC | Set of prenatal earbud adapters |
CN111062854B (en) * | 2019-12-26 | 2023-08-25 | Oppo广东移动通信有限公司 | Method, device, terminal and storage medium for detecting watermark |
Citations (40)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4837422A (en) * | 1987-09-08 | 1989-06-06 | Juergen Dethloff | Multi-user card system |
US5319735A (en) * | 1991-12-17 | 1994-06-07 | Bolt Beranek And Newman Inc. | Embedded signalling |
US5337361A (en) * | 1990-01-05 | 1994-08-09 | Symbol Technologies, Inc. | Record with encoded data |
US5379344A (en) * | 1990-04-27 | 1995-01-03 | Scandic International Pty. Ltd. | Smart card validation device and method |
US5499293A (en) * | 1995-01-24 | 1996-03-12 | University Of Maryland | Privacy protected information medium using a data compression method |
US5613004A (en) * | 1995-06-07 | 1997-03-18 | The Dice Company | Steganographic method and device |
US5659726A (en) * | 1995-02-23 | 1997-08-19 | Sandford, Ii; Maxwell T. | Data embedding |
US5664018A (en) * | 1996-03-12 | 1997-09-02 | Leighton; Frank Thomson | Watermarking process resilient to collusion attacks |
US5663766A (en) * | 1994-10-31 | 1997-09-02 | Lucent Technologies Inc. | Digital data encoding in video signals using data modulated carrier signals at non-peaks in video spectra |
US5721788A (en) * | 1992-07-31 | 1998-02-24 | Corbis Corporation | Method and system for digital image signatures |
US5790662A (en) * | 1994-11-15 | 1998-08-04 | Landis & Gyr Technology Innovation Ag | Data carrier and write/read device therefor |
US5799092A (en) * | 1995-02-28 | 1998-08-25 | Lucent Technologies Inc. | Self-verifying identification card |
US5835639A (en) * | 1996-12-18 | 1998-11-10 | Eastman Kodak Company | Method for detecting rotation and magnification in images |
US5848155A (en) * | 1996-09-04 | 1998-12-08 | Nec Research Institute, Inc. | Spread spectrum watermark for embedded signalling |
US5859920A (en) * | 1995-11-30 | 1999-01-12 | Eastman Kodak Company | Method for embedding digital information in an image |
US5949055A (en) * | 1997-10-23 | 1999-09-07 | Xerox Corporation | Automatic geometric image transformations using embedded signals |
US5960081A (en) * | 1997-06-05 | 1999-09-28 | Cray Research, Inc. | Embedding a digital signature in a video sequence |
US6031914A (en) * | 1996-08-30 | 2000-02-29 | Regents Of The University Of Minnesota | Method and apparatus for embedding data, including watermarks, in human perceptible images |
US6069914A (en) * | 1996-09-19 | 2000-05-30 | Nec Research Institute, Inc. | Watermarking of image data using MPEG/JPEG coefficients |
US6122403A (en) * | 1995-07-27 | 2000-09-19 | Digimarc Corporation | Computer system linked by using information in data objects |
US6268058B1 (en) * | 1997-10-24 | 2001-07-31 | Agfa-Gevaert | Security card comprising a thin glass layer |
US6285776B1 (en) * | 1994-10-21 | 2001-09-04 | Digimarc Corporation | Methods for identifying equipment used in counterfeiting |
US20010030759A1 (en) * | 2000-01-31 | 2001-10-18 | Junichi Hayashi | Image processing apparatus for determining specific images |
US6314192B1 (en) * | 1998-05-21 | 2001-11-06 | Massachusetts Institute Of Technology | System, method, and product for information embedding using an ensemble of non-intersecting embedding generators |
US6343138B1 (en) * | 1993-11-18 | 2002-01-29 | Digimarc Corporation | Security documents with hidden digital data |
US6389421B1 (en) * | 1997-12-11 | 2002-05-14 | International Business Machines Corporation | Handling processor-intensive operations in a data processing system |
US6411392B1 (en) * | 1998-04-15 | 2002-06-25 | Massachusetts Institute Of Technology | Method and apparatus for data hiding in printed images |
US20020114491A1 (en) * | 2000-12-21 | 2002-08-22 | Sharma Ravi K. | Detection of multiple watermarks and improved watermark calibration signals |
US20020120849A1 (en) * | 2000-02-14 | 2002-08-29 | Mckinley Tyler J. | Parallel processing of digital watermarking operations |
US6556689B1 (en) * | 1998-05-29 | 2003-04-29 | University Of Delaware | Watermarking methods for digital images and videos |
US20030128861A1 (en) * | 1993-11-18 | 2003-07-10 | Rhoads Geoffrey B. | Watermark embedder and reader |
US6611830B2 (en) * | 1998-02-12 | 2003-08-26 | Hitachi, Ltd. | Information search method and system for registering and searching for associated multimedia data using embedded information |
US6614914B1 (en) * | 1995-05-08 | 2003-09-02 | Digimarc Corporation | Watermark embedder and reader |
US20040181671A1 (en) * | 1998-11-19 | 2004-09-16 | Brundage Trent J. | Identification document and related methods |
US6947571B1 (en) * | 1999-05-19 | 2005-09-20 | Digimarc Corporation | Cell phones with optical capabilities, and related applications |
US6952485B1 (en) * | 2000-09-11 | 2005-10-04 | Digimarc Corporation | Watermark encoding and decoding in imaging devices and imaging device interfaces |
US6965682B1 (en) * | 1999-05-19 | 2005-11-15 | Digimarc Corp | Data transmission by watermark proxy |
US6975745B2 (en) * | 2001-10-25 | 2005-12-13 | Digimarc Corporation | Synchronizing watermark detectors in geometrically distorted signals |
US7013021B2 (en) * | 1999-03-19 | 2006-03-14 | Digimarc Corporation | Watermark detection utilizing regions with higher probability of success |
US7116781B2 (en) * | 1993-11-18 | 2006-10-03 | Digimarc Corporation | Counteracting geometric distortions in watermarking |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020009208A1 (en) * | 1995-08-09 | 2002-01-24 | Adnan Alattar | Authentication of physical and electronic media objects using digital watermarks |
US8144368B2 (en) * | 1998-01-20 | 2012-03-27 | Digimarc Coporation | Automated methods for distinguishing copies from original printed objects |
US20020159614A1 (en) * | 2000-12-18 | 2002-10-31 | Bradley Brett Alan | Message coding for digital watermark applications |
US7607016B2 (en) * | 2001-04-20 | 2009-10-20 | Digimarc Corporation | Including a metric in a digital watermark for media authentication |
WO2002091374A1 (en) * | 2001-05-08 | 2002-11-14 | Koninklijke Philips Electronics N.V. | Watermarking |
US6724914B2 (en) * | 2001-10-16 | 2004-04-20 | Digimarc Corporation | Progressive watermark decoding on a distributed computing platform |
US7231061B2 (en) * | 2002-01-22 | 2007-06-12 | Digimarc Corporation | Adaptive prediction filtering for digital watermarking |
US20030204718A1 (en) * | 2002-04-29 | 2003-10-30 | The Boeing Company | Architecture containing embedded compression and encryption algorithms within a data file |
US7519819B2 (en) * | 2002-05-29 | 2009-04-14 | Digimarc Corporatino | Layered security in digital watermarking |
US20040258274A1 (en) * | 2002-10-31 | 2004-12-23 | Brundage Trent J. | Camera, camera accessories for reading digital watermarks, digital watermarking method and systems, and embedding digital watermarks with metallic inks |
US8891811B2 (en) | 2004-09-17 | 2014-11-18 | Digimarc Corporation | Hierarchical watermark detector |
EP2109304A1 (en) | 2008-04-07 | 2009-10-14 | Océ-Technologies B.V. | Color management method, module, and program product, and printer ussing said method |
-
2005
- 2005-09-14 US US11/228,033 patent/US8891811B2/en active Active
-
2014
- 2014-11-18 US US14/546,708 patent/US9412144B2/en active Active
-
2016
- 2016-08-09 US US15/232,388 patent/US9898792B2/en active Active
-
2018
- 2018-02-19 US US15/899,292 patent/US10607311B2/en active Active
Patent Citations (43)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4837422A (en) * | 1987-09-08 | 1989-06-06 | Juergen Dethloff | Multi-user card system |
US5337361A (en) * | 1990-01-05 | 1994-08-09 | Symbol Technologies, Inc. | Record with encoded data |
US5337361C1 (en) * | 1990-01-05 | 2001-05-15 | Symbol Technologies Inc | Record with encoded data |
US5379344A (en) * | 1990-04-27 | 1995-01-03 | Scandic International Pty. Ltd. | Smart card validation device and method |
US5319735A (en) * | 1991-12-17 | 1994-06-07 | Bolt Beranek And Newman Inc. | Embedded signalling |
US5721788A (en) * | 1992-07-31 | 1998-02-24 | Corbis Corporation | Method and system for digital image signatures |
US20030128861A1 (en) * | 1993-11-18 | 2003-07-10 | Rhoads Geoffrey B. | Watermark embedder and reader |
US7116781B2 (en) * | 1993-11-18 | 2006-10-03 | Digimarc Corporation | Counteracting geometric distortions in watermarking |
US6343138B1 (en) * | 1993-11-18 | 2002-01-29 | Digimarc Corporation | Security documents with hidden digital data |
US6285776B1 (en) * | 1994-10-21 | 2001-09-04 | Digimarc Corporation | Methods for identifying equipment used in counterfeiting |
US5663766A (en) * | 1994-10-31 | 1997-09-02 | Lucent Technologies Inc. | Digital data encoding in video signals using data modulated carrier signals at non-peaks in video spectra |
US5790662A (en) * | 1994-11-15 | 1998-08-04 | Landis & Gyr Technology Innovation Ag | Data carrier and write/read device therefor |
US5499293A (en) * | 1995-01-24 | 1996-03-12 | University Of Maryland | Privacy protected information medium using a data compression method |
US5659726A (en) * | 1995-02-23 | 1997-08-19 | Sandford, Ii; Maxwell T. | Data embedding |
US5799092A (en) * | 1995-02-28 | 1998-08-25 | Lucent Technologies Inc. | Self-verifying identification card |
US6614914B1 (en) * | 1995-05-08 | 2003-09-02 | Digimarc Corporation | Watermark embedder and reader |
US5687236A (en) * | 1995-06-07 | 1997-11-11 | The Dice Company | Steganographic method and device |
US5613004A (en) * | 1995-06-07 | 1997-03-18 | The Dice Company | Steganographic method and device |
US6122403A (en) * | 1995-07-27 | 2000-09-19 | Digimarc Corporation | Computer system linked by using information in data objects |
US5859920A (en) * | 1995-11-30 | 1999-01-12 | Eastman Kodak Company | Method for embedding digital information in an image |
US5664018A (en) * | 1996-03-12 | 1997-09-02 | Leighton; Frank Thomson | Watermarking process resilient to collusion attacks |
US6031914A (en) * | 1996-08-30 | 2000-02-29 | Regents Of The University Of Minnesota | Method and apparatus for embedding data, including watermarks, in human perceptible images |
US5848155A (en) * | 1996-09-04 | 1998-12-08 | Nec Research Institute, Inc. | Spread spectrum watermark for embedded signalling |
US6069914A (en) * | 1996-09-19 | 2000-05-30 | Nec Research Institute, Inc. | Watermarking of image data using MPEG/JPEG coefficients |
US5835639A (en) * | 1996-12-18 | 1998-11-10 | Eastman Kodak Company | Method for detecting rotation and magnification in images |
US5960081A (en) * | 1997-06-05 | 1999-09-28 | Cray Research, Inc. | Embedding a digital signature in a video sequence |
US5949055A (en) * | 1997-10-23 | 1999-09-07 | Xerox Corporation | Automatic geometric image transformations using embedded signals |
US6268058B1 (en) * | 1997-10-24 | 2001-07-31 | Agfa-Gevaert | Security card comprising a thin glass layer |
US6389421B1 (en) * | 1997-12-11 | 2002-05-14 | International Business Machines Corporation | Handling processor-intensive operations in a data processing system |
US6611830B2 (en) * | 1998-02-12 | 2003-08-26 | Hitachi, Ltd. | Information search method and system for registering and searching for associated multimedia data using embedded information |
US6411392B1 (en) * | 1998-04-15 | 2002-06-25 | Massachusetts Institute Of Technology | Method and apparatus for data hiding in printed images |
US6314192B1 (en) * | 1998-05-21 | 2001-11-06 | Massachusetts Institute Of Technology | System, method, and product for information embedding using an ensemble of non-intersecting embedding generators |
US6556689B1 (en) * | 1998-05-29 | 2003-04-29 | University Of Delaware | Watermarking methods for digital images and videos |
US20040181671A1 (en) * | 1998-11-19 | 2004-09-16 | Brundage Trent J. | Identification document and related methods |
US7013021B2 (en) * | 1999-03-19 | 2006-03-14 | Digimarc Corporation | Watermark detection utilizing regions with higher probability of success |
US6947571B1 (en) * | 1999-05-19 | 2005-09-20 | Digimarc Corporation | Cell phones with optical capabilities, and related applications |
US6965682B1 (en) * | 1999-05-19 | 2005-11-15 | Digimarc Corp | Data transmission by watermark proxy |
US20010030759A1 (en) * | 2000-01-31 | 2001-10-18 | Junichi Hayashi | Image processing apparatus for determining specific images |
US7142689B2 (en) * | 2000-01-31 | 2006-11-28 | Canon Kabushiki Kaisha | Image processing apparatus for determining specific images |
US20020120849A1 (en) * | 2000-02-14 | 2002-08-29 | Mckinley Tyler J. | Parallel processing of digital watermarking operations |
US6952485B1 (en) * | 2000-09-11 | 2005-10-04 | Digimarc Corporation | Watermark encoding and decoding in imaging devices and imaging device interfaces |
US20020114491A1 (en) * | 2000-12-21 | 2002-08-22 | Sharma Ravi K. | Detection of multiple watermarks and improved watermark calibration signals |
US6975745B2 (en) * | 2001-10-25 | 2005-12-13 | Digimarc Corporation | Synchronizing watermark detectors in geometrically distorted signals |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110007935A1 (en) * | 2000-04-19 | 2011-01-13 | Reed Alastair M | Digital Watermarking in Data Representing Color Channels |
US8027509B2 (en) * | 2000-04-19 | 2011-09-27 | Digimarc Corporation | Digital watermarking in data representing color channels |
US9179033B2 (en) | 2000-04-19 | 2015-11-03 | Digimarc Corporation | Digital watermarking in data representing color channels |
US9940685B2 (en) | 2000-04-19 | 2018-04-10 | Digimarc Corporation | Digital watermarking in data representing color channels |
US8890950B2 (en) | 2010-05-05 | 2014-11-18 | Digimarc Corporation | Methods and arrangements for processing image data |
US20150145687A1 (en) * | 2013-11-22 | 2015-05-28 | Aps Technology, Inc. | System, Apparatus, and Method for Drilling |
US10190408B2 (en) * | 2013-11-22 | 2019-01-29 | Aps Technology, Inc. | System, apparatus, and method for drilling |
US11049094B2 (en) | 2014-02-11 | 2021-06-29 | Digimarc Corporation | Methods and arrangements for device to device communication |
US9959586B1 (en) * | 2016-12-13 | 2018-05-01 | GoAnimate, Inc. | System, method, and computer program for encoding and decoding a unique signature in a video file as a set of watermarks |
WO2024020638A1 (en) * | 2022-07-27 | 2024-02-01 | GeoSnapshot Pty Ltd | Inspection of digital images through watermarks |
Also Published As
Publication number | Publication date |
---|---|
US9412144B2 (en) | 2016-08-09 |
US9898792B2 (en) | 2018-02-20 |
US20170039669A1 (en) | 2017-02-09 |
US10607311B2 (en) | 2020-03-31 |
US8891811B2 (en) | 2014-11-18 |
US20180276782A1 (en) | 2018-09-27 |
US20150154724A1 (en) | 2015-06-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10607311B2 (en) | Hierarchical watermark detector | |
US11194984B2 (en) | Localization of machine-readable indicia in digital capture systems | |
US10460413B2 (en) | Feature-based signal localization in digital capture systems | |
US11238556B2 (en) | Embedding signals in a raster image processor | |
US10282470B2 (en) | Distributed computing for portable computing devices | |
US7957552B2 (en) | Optimized digital watermarking functions for streaming data | |
US6952485B1 (en) | Watermark encoding and decoding in imaging devices and imaging device interfaces | |
US8774451B2 (en) | Method and apparatus for embedding a watermark image in a host image | |
CN110264442A (en) | A kind of integrity check method of watermark, electronic equipment and readable storage medium storing program for executing | |
JP4516629B2 (en) | Pattern detection program, pattern detection method, and pattern detection apparatus | |
Alattar et al. | A fast hierarchical watermark detector for real-time software or low-cost hardware implementation | |
Alattar et al. | Reducing the processing time of the hierarchical watermark detector when applied to unmarked images | |
Serpanos et al. | Multimedia Watermarking | |
AU2005202688A1 (en) | Anti Collusion Signal Embedding Method |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: DIGIMARC CORPORATION, OREGON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ALATTAR, OSAMA M.;ALATTAR, ADNAN M.;REEL/FRAME:017316/0794 Effective date: 20051117 |
|
AS | Assignment |
Owner name: DIGIMARC CORPORATION (FORMERLY DMRC CORPORATION), Free format text: CONFIRMATION OF TRANSFER OF UNITED STATES PATENT RIGHTS;ASSIGNOR:L-1 SECURE CREDENTIALING, INC. (FORMERLY KNOWN AS DIGIMARC CORPORATION);REEL/FRAME:021785/0796 Effective date: 20081024 Owner name: DIGIMARC CORPORATION (FORMERLY DMRC CORPORATION), OREGON Free format text: CONFIRMATION OF TRANSFER OF UNITED STATES PATENT RIGHTS;ASSIGNOR:L-1 SECURE CREDENTIALING, INC. (FORMERLY KNOWN AS DIGIMARC CORPORATION);REEL/FRAME:021785/0796 Effective date: 20081024 Owner name: DIGIMARC CORPORATION (FORMERLY DMRC CORPORATION),O Free format text: CONFIRMATION OF TRANSFER OF UNITED STATES PATENT RIGHTS;ASSIGNOR:L-1 SECURE CREDENTIALING, INC. (FORMERLY KNOWN AS DIGIMARC CORPORATION);REEL/FRAME:021785/0796 Effective date: 20081024 |
|
AS | Assignment |
Owner name: DIGIMARC CORPORATION (AN OREGON CORPORATION), OREGON Free format text: MERGER;ASSIGNOR:DIGIMARC CORPORATION (A DELAWARE CORPORATION);REEL/FRAME:024369/0582 Effective date: 20100430 Owner name: DIGIMARC CORPORATION (AN OREGON CORPORATION),OREGO Free format text: MERGER;ASSIGNOR:DIGIMARC CORPORATION (A DELAWARE CORPORATION);REEL/FRAME:024369/0582 Effective date: 20100430 Owner name: DIGIMARC CORPORATION (AN OREGON CORPORATION), OREG Free format text: MERGER;ASSIGNOR:DIGIMARC CORPORATION (A DELAWARE CORPORATION);REEL/FRAME:024369/0582 Effective date: 20100430 |
|
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) Year of fee payment: 4 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 8 |