The invention relates generally to the field of content display. In particular, it relates to the deterrence of unauthorised reuse of display content for display on computer screens.
With the rapid growth of the Internet, more and more images are accessible to Internet users. However, not all providers of images on the Internet are willing to permit users to keep the images provided and displayed on screens, much less allow the users to distribute the images at will. Present network protocols such as the HyperText Transfer Protocol (HTTP) do not address the issue of protecting images or other display content such as text downloaded from websites or other remote resources. As a result, any user who has access to a website is able to save and reuse display content downloaded from that website. This is because a number of World Wide Web (WWW) browsers provide a save function allowing users to save a web page and a composer feature which the users can use to edit the saved display content A user can also type a Print Screen key typically found on the keyboard of a computer to perform screen dumps or capture snapshots of a series of images stored in the video buffer of the computer by duplicating the video buffer. Using programs that enable the user to create, view, and edit images, the user can then easily obtain the images by retrieving these snapshots.
It is hence difficult to prevent unauthorised reuse of display content downloaded from or provided via a remote resource. A diligent pirate can reuse both text and images by re-typing the text and performing screen dumps of the images shown on the screen. It is therefore desirable to deter unauthorised reuse of display content by either forcing a pirate to spend significant amounts of money and time to obtain display content, or degrading the quality of reused screen content. To this end, a number of patents and conventional technologies have been proposed which are described hereinafter.
In U.S. Pat. No. 5,905,505, a method and a system for copy protection of on-screen display of text are disclosed, in which embodiments described therein prevent screen dumps of text displayed on computer screens by first having the text transformed into a textual image. In a first embodiment, two random background images are generated and added to the textual image to produce two composite images. The two composite images are then alternately displayed on a screen to simulate the on-screen rendering of the textual image. In a second embodiment, the textual image is modified to produce two random bitmapped images. The two random bitmapped images are then alternately displayed for simulating the on-screen rendering of the textual image. Although in both cases the textual image is irretrievable by performing screen dumps, because only one of the pair of composite or random bitmapped images can be captured as a snapshot each instant, a user acquires a visual perception resembling the textual image by averaging each pair of composite or random bitmapped images as these are alternately displayed on the screen. However, the embodiments work adequately only for high contrast images such as textual images but not for display content with low contrast such as pictures.
In U.S. Pat. No. 6,209,103, a method and an apparatus for preventing reuse of text, images and software transmitted via networks are disclosed, which involve the transformation of textual information into images. In one embodiment, text is transformed into a textual image. In a further embodiment, an image is divided into multiple sub-images with each sub-image being a component of the image or an interference pattern is incorporated into different locations of the image to form multiple interference images with each interference image having a pattern at a unique location. An applet then displays these multiple images in succession over intervals. With these multiple images a user can only acquire a visual perception which resembles the original image but cannot obtain such an image from capturing snapshot of the video buffer once. Unfortunately, a pirate can still recover the image by capturing the video buffer several times to obtain all of the multiple images by trial. Generally, the number of attempts the pirate need to make to capture all of the multiple images is small because the number of sub-images is restricted by the screen's display refresh rate, which is usually less than 100 Hz.
In U.S. Pat. No. 5,881,287, a method and an apparatus for copy protection of images in a computer system are disclosed which prevent unlicensed transfers of image data from a video adapter to other storage means. This is done by the interception of data transfer requests made to an operating system and identifying whether an image requested is one to be protected. If the image requested is one that is marked for protection, any data transfer incorporating the protected image is obscured, blacked out or replaced with another specified pattern or message. However, such a protection system can be easily bypassed. A pirate can load a hook program which intercepts the request before the protection system intercepts the request. For instance, when a user types the Print-Screen key on a computer keyboard, a hook program can intercept the Print-Screen request and copies the video buffer into another storage medium before the protection system can black out the snapshot.
In U.S. Pat. No. 6,208,735, a secure spread spectrum watermarking method for is multimedia data is disclosed, which uses digital watermark technology to embed a watermark representing copyright into protected content so as to indicate ownership of the protected content. To remove the watermark, a pirate has to degrade the quality of the protected content. However, this method cannot prevent unauthorised reuse of the protected content.
In Microsoft's windows operating systems, an application program interface (API) such as the sethook( ) function is typically provided for intercepting a computer keyboard event. When a user types the Print-Screen key on a computer keyboard of a computer, the keyboard event can be intercepted by a hook application based on the sethook( ) function, which would prevent the default process of copying the content of the computer's video buffer onto a clipboard thus preventing reuse of information stored in the video buffer. The disadvantage of doing this is that the API sethook( ) function is a standalone application which has to be executed with a local user priority. This protection system is therefore not applicable to mobile codes such as Java applets.
There is therefore a need for a display content reuse deterrence system for addressing the foregoing problems.
An image is shown on a computer screen in the spatial domain. The human visual perception system, however, is sensitive to the frequency domain. To involve visual perception by the human visual perception system in the deterrence of reuse of display content, a system is disclosed in which an image is transformed into the frequency domain with corresponding frequency components. For every frequency component, a random number sequence is generated and a variant of the random number sequence is generated based on the value of the frequency component. The arithmetic mean value of any predefined length of segment of the random number sequence preferably tends to 0. A number is selected from every random number sequence and a noise image formed using the value of this number. The image in the frequency domain is combined with the noise image to generate a synthesised image known as a noise-deteriorated image, which is then transformed back to the spatial domain. From every random number sequence, multiple numbers are selected to generate multiple synthesised images for forming an image sequence. The image sequence is then displayed on the computer screen.
In such a system, an input such as an original image X, is processed into an output which consists of a sequence of noise-deteriorated images {tilde over (X)}k for rendering on the computer screen.
During preparation, the system transforms X into m components f1, f2, . . . , fm in the frequency domain F The system then generates a noise number sequence ri={ri1, ri2, . . . } for each components fi. i=1, 2, . . . , m before generating the noise-deteriorated images. Alternatively, each number in the noise number sequences can be generated while generating the corresponding noise-deteriorated image.
To generate the noise-deteriorated images, the system performs the following operations:
In accordance with a first aspect of the invention, a method for generating a plurality of noise-deteriorated images from an image displayable on a computer display for deterring unauthorised reuse of the image is disclosed, in which the method comprising the steps of:
In accordance with a second aspect of the invention, a system for generating a plurality of noise-deteriorated images from an image displayable on a computer display for deterring unauthorised reuse of the image, in which the system comprises:
Embodiments of the invention are described hereinafter in detail with reference to the drawings, in which:
Embodiments of the invention are disclosed hereinafter for addressing the need for a display content reuse deterrence system.
In the field of vision sciences, the Talbot-Plateau Law states that the brightness of intermittent light is equal to the brightness of steady light with the same time-averaged luminance. For the Talbot-Plateau Law to apply, the intermittent light must illuminate at a rate beyond the Critical Flicker Frequency (CFF), which is the frequency at which flicker induced by intermittent illumination disappears. The Talbot-Plateau Law holds because when the human eye is presented with images changing at a rate above 24 frames per second, the human eye averages the images to visually perceive an averaged representation of the images rather than perceive the images separately.
The embodiments described hereinafter aim to prevent reuse of display content while providing good visual perception quality. Measurements of vision perception quality vary because of different criteria for vision perceptual. The embodiments primarily focus on the criterion of screen flicker.
Assume X is the original image, and Xk is an image at a kth frame shown on the screen in a sequence of T images which can be copied from a video buffer of a computer on which X is displayed by performing a screen dump. Generally, any display content reuse deterrence system should satisfy the following requirements:
The first requirement aims to reduce screen flicker to a minimum so as to display an image of high quality to authorised users. The other requirements aim to introduce interference into the video buffer so that any screen dump cannot result in a high quality image. The first requirement appears to contradict the others and a trade-off is therefore necessary for a display content reuse deterrence system to perform adequately.
To meet all three requirements by the embodiments, a series of interference or noise images is added to the original image to generate a sequence of degraded or noise-deteriorated images which are rendered in succession and repeatedly in place of the original image. Although the noise-deteriorated images are displayed, an authorised user can visually perceive the original image with high quality.
All the pixels in an image are affected when the image is modified in the frequency domain. Applying interference to an image in the frequency domain can therefore satisfy the third requirement.
There are two types of frequency components in an image, namely high and low frequency components. The high frequency components represent sharp or abrupt changes in the image while the low frequency components represent smooth or slow changes such as those found in a uniform region in the image. To meet the second requirement, high amplitude noise can be added to the high frequency components of the image to increase interference or noise in the image.
The embodiments are described in detail hereinafter with reference to FIGS. 1 to 4. In
Corresponding to each frequency component fi, a random number sequence ri={rij, where j=1, 2, . . . } is generated. In order to generate a kth synthesised image as display content for the kth display frame on the monitor 120 in a sequence of synthesised images, a corresponding kth interference or noise image is generated by using rat (i=1, 2, . . . , m) in a step 215. Alternatively, a random number resource may be used in this step 215 to generate the kth interference image. Thus the kth synthesised image can then be generated by fi+rik, where i=1, 2, . . . , m, in a step 220.
In a step 230, the kth synthesised image is transformed back to the spatial domain by reverse transformation. In a step 240, the spatial domain image of the kth synthesised image is provided as output to the monitor 160 for display as the kth display frame in the sequence of display frames.
In order to obtain a stable and flicker free image and prevent unauthorised reuse of the original image, the foregoing steps are preferably iterated indefinitely. Additionally, the random number sequence for each frequency component is preferably generated with the arithmetic mean value of each segment of the random number sequence of predefined length T tending to zero. This is because the predefined length T of each segment of the random number sequence for each frequency component is related to the noise amplitude, the frequency and perception tolerance of flicker. However, the smaller T is, the better the quality of the visual perception of the original image.
There are a number of ways to generate the interference images.
In a step 320, a uniform-distribution random number sequence within interval (−1.0, 1.0) is generated from the seed of the hash value v by using a random function such as rand( ). In a step 330, for each ith frequency component a new hash value h(v|i) is calculated, this new hash value marking the start position of a new random number sequence for the ith frequency component, where h( ) is a hash function.
In a step 340, based on the amplitude of the ith frequency component and properties of the human visual perception system, the amplitude of the new random number sequence for the ith frequency component is adjusted to a suitable level. In a step 350, all noise components for the frequency components relating to the kth display frame are combined, forming the kth noise image in the frequency domain.
The foregoing processes are more clearly described using an example shown in
Given the 2×2 pixels original image 410, a noise number sequence is generated as follows:
The noise number sequence is then truncated into sub-sequences 420 and adjusted to appropriate amplitudes using a parameter {αi}. Each of the sub-sequences 420 also tends to zero if it is of sufficient length. These sub-sequences 420 are denoted as {r1}, {r2}, {r3} and {r4},
{r1}=α1{R1, R2, R3, R4, R5, . . . }={r11, r12, r13, r14, r15, r16, . . . }
{r2}=α2{R2, R3, R4, R5, R6, . . . }={r21, r22, r23, r24, r25, r26, . . . }
{r3}=α3{R3, R4, R5, R6, R7, . . . }={r31, r32, r33, r34, r35, r36, . . . }
{r4}=α4{R4, R5, R6, R7, R8, . . . }={r41, r42, r43, r44, r45, r46, . . . . }
For purposes of illustration, it is assumed that the 5th (i.e., k=5) frame is to be rendered. A noise image 430 is created with elements from the sub-sequences 420 corresponding to the kth display frame. The noise image 430 is added to the original image in the frequency domain 440 to form the k synthesised 450 image which is then transformed into the spatial domain. The kth synthesised image in the spatial domain 460 can then be rendered on the monitor 160 during the kth display frame.
In the foregoing manner, a display content reuse deterrence system is disclosed. Although only a number of embodiments are described, it will be apparent to one skilled in the art in view of this disclosure that numerous changes and/or modifications can be made to such a system without departing from the scope and spirit of the invention.
In this system, an input such as an original image X, is processed into an output which consists of a sequence of noise-deteriorated images {tilde over (X)}k for rendering on the computer screen.
During preparation, the system transforms X into m components f1, f2, . . . , fm in the frequency domain F. The system then generates a noise number sequence ri={ri1, ri2, . . . } for each component fi. i=1, 2, . . . , m before generating the noise-deteriorated images. Alternatively, each number in the noise number sequences can be generated while generating the corresponding noise-deteriorated image.
To generate the noise-deteriorated images, the system then performs the following operations:
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/SG02/00179 | 8/7/2002 | WO | 9/28/2005 |