WO2010024907A1 - Systems and methods for compression transmission and decompression of video codecs - Google Patents

Systems and methods for compression transmission and decompression of video codecs Download PDF

Info

Publication number
WO2010024907A1
WO2010024907A1 PCT/US2009/004879 US2009004879W WO2010024907A1 WO 2010024907 A1 WO2010024907 A1 WO 2010024907A1 US 2009004879 W US2009004879 W US 2009004879W WO 2010024907 A1 WO2010024907 A1 WO 2010024907A1
Authority
WO
WIPO (PCT)
Prior art keywords
frame
processing
video
row
post
Prior art date
Application number
PCT/US2009/004879
Other languages
French (fr)
Inventor
Angel Decegama
Original Assignee
Angel Decegama
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Angel Decegama filed Critical Angel Decegama
Priority to EP09810374A priority Critical patent/EP2370934A4/en
Priority to US12/657,100 priority patent/US20100172419A1/en
Publication of WO2010024907A1 publication Critical patent/WO2010024907A1/en
Priority to US12/806,153 priority patent/US8031782B2/en
Priority to US13/240,712 priority patent/US8503543B2/en
Priority to US13/958,945 priority patent/US20130315317A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/59Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/587Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal sub-sampling or interpolation, e.g. decimation or subsequent interpolation of pictures in a video sequence
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/63Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using sub-band based transform, e.g. wavelets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/63Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using sub-band based transform, e.g. wavelets
    • H04N19/64Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using sub-band based transform, e.g. wavelets characterised by ordering of coefficients or of bits for transmission
    • H04N19/647Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using sub-band based transform, e.g. wavelets characterised by ordering of coefficients or of bits for transmission using significance based coding, e.g. Embedded Zerotrees of Wavelets [EZW] or Set Partitioning in Hierarchical Trees [SPIHT]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/85Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression

Definitions

  • This invention relates to the field of video compression when it is desired to minimize the amount of bytes needed to reproduce the different video frames with a desired visual quality while reducing the corresponding costs of storage and transmission.
  • this invention relates to wavelet transformation methods to improve the performance of any video codec to compress and decompress video frames.
  • Video communications systems are being swamped by increasing amounts of data and current video compression techniques have remained almost stagnant in recent years. New techniques are needed to significantly cut the video data storage and transmission requirements.
  • Embodiments of the invention involve pre-processing a video image, decimating the image using WT, taking the decimated WT of a given video frame down several levels and keeping only the low-frequency part at each level.
  • WT decimated WT
  • a video codec operates in its usual fashion on such a "pre-processed frame” or “reduced frame” to compress the image and further decrease the amount of information that is needed to be stored and transmitted. Then, the data representing the pre-processed frame compressed using a codec can be transmitted with high efficiency because the number of bits of information has been reduced substantially compared to either the original frame, or the frame that had been processed by the codec alone.
  • FIG. 1 depicts a schematic drawing 100a of a method of this invention.
  • Input Video File 10 is received by a computer input device, and is then pre-processed by Size
  • Video File 30 is then processed by Codec 40a, thereby producing Compressed Video File
  • Codec 40b decompresses Compressed Video File 50 to produce Decompressed Video File 60 being 1 A, 1/16, 1/64 etc. of the original size of Input Video File 10.
  • Application of a post-processing method of Frame Expansion 70 produces Output Video File 80 having a full size image which is then displayed on video monitor 90 or is stored in a memory device 100.
  • Transmission Process 55 can transmit Compressed Video File 50 to a remote location, where it can be decompressed by the codec and post- processed according to methods of this invention, and displayed on a video monitor or stored for future use.
  • FIG. 2 depicts a general schematic drawing 200 showing how an original frame is reduced using frame pre-processing methods of this invention.
  • Original Frame 210 is first treated to decimate low frequency (LF) components of the WT 220, which are kept.
  • High frequency (HF) components 230 are discarded.
  • 220 is then further pre- processed in step 235, again decimating low frequency (LF) components of the WT 240, which are kept.
  • High frequency (HF) components 250 are discarded.
  • the process can be repeated as desired through 3, 4, 5, 6, or even more levels.
  • FIG. 3 depicts a general schematic drawing 300 showing frame size expansion according to an embodiment of this invention.
  • Reduced Size 310 is vertically expanded in step 315, thereby producing Vertically Expanded Frame 320, which is then horizontally expanded in step 325 producing Horizontally Expanded Frame 330.
  • Horizontally Expanded Frame 330 is vertically expanded in step 335 thereby producing Vertically Expanded 340, which is horizontally expanded in step 345, thereby producing Horizontally Expanded Frame 350.
  • the process can be repeated as many times as desired through 3, 4, 5, 6 or more levels.
  • Pre-processing methods of this invention can result in a size reduction for the frame of 1 A for one level of transformation or 1/16 for two levels of transformation, and so on. This can be done for all frames in a given video sequence. Then the reduced frames are used to create a new video file, for example, in .avi format. It can be appreciated that other file formats can also be used, including for example, OG3, Asf, Quick Time, Real Media, Matroska, DIVX and MP4. This file is then input to any available codec of choice and it is compressed by the codec following its standard procedure to a size which typically ranges from 40% (one level of WT) to less than 20% (two levels or more of WT) of the compressed size obtained without the step of frame size reduction. Such files can be stored and/or transmitted with very significant cost savings. By appropriately interfacing with the codec, such procedure can be carried out frame by frame instead of having to create an intermediate file.
  • the codec For decompression of each frame, the codec is used in its normal way and a file
  • the final step is to generate a file where all the frames are full size with the file size being the same as that of the original uncompressed file.
  • This step can be accomplished frame by frame without producing the intermediate file, further improving the efficiency of the process.
  • a series of frames can be pre-processed, compressed, transmitted, decompressed, post-processed and displayed in real time, thereby producing a high quality video, such as a movie or live broadcast. Because the steps in pre- processing, compression, decompression, post-processing can be carried out very rapidly, a reproduced video (e.g., a movie or live broadcast), can be viewed in real time.
  • a reproduced video e.g., a movie or live broadcast
  • this invention provides a system for video image compression and decompression, comprising: a first computer module for image frame pre-processing using direct wavelet transformation (WT); a video codec; a second computer module for image frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT and an output device.
  • WT direct wavelet transformation
  • a video codec a computer module for image frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT and an output device.
  • this invention provides a system wherein said first computer module comprises: an input buffer for storing a video image frame; a memory device storing instructions for frame pre-processing, wherein said instructions are based upon direct wavelet transformation (WT); a processor for implementing said instructions for frame pre-processing, and an output.
  • said second computer module comprises: an input buffer; a memory device storing instructions for frame post-processing, wherein said instructions are based upon using low-frequency parts of the WT plus the last pixel of every row and column of the original image before the WT; a processor for implementing said instructions for frame post-processing; and an output.
  • this invention provides systems further comprising another storage device for storing a post-processed frame of said video image.
  • a system of this invention includes instructions for frame preprocessing using decimated WT and retaining low frequency part of said decimated WT and discarding high-frequency part of the decimated WT.
  • a system of this invention includes instructions for frame post-processing to recreate a post-processed frame by using low- frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
  • a system of this invention includes instructions for frame postprocessing to recreate a full sized post-processed frame by using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
  • this invention provides an integrated computer device for preprocessing a video image frame, comprising: a computer storage module containing instructions for frame pre-processing according to decimated WT; and a processor for processing said decimated WT by retaining low-frequency parts and discarding high-frequency parts.
  • this invention provides an integrated computer device for post-processing a video image frame, comprising: a computer storage module containing instructions for frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT; and a processor for processing said computations to re-create a full-size video image.
  • this invention provides a computer readable medium, comprising: a medium; and instructions thereon to pre-process a video frame using WT.
  • this invention provides a computer readable medium, comprising: a medium; and instructions thereon to post-process a reduced video frame to re-create a video frame of original size using low-frequency parts of the WT plus the last pixel of every row and column of the original image before the WT.
  • a computer readable medium is a diskette, compact disk (CD), magnetic tape, paper or punch card.
  • the Haar WT is used.
  • Daubechies - 4 Daubechies - 6, Daubechies - 8, biorthogonal or asymmetrical wavelets can be used.
  • Systems of this invention can provide high-quality reproduction of video images in real time. In some aspects, systems can provide over 50% reduction in storage space.
  • systems can provide over 50% reduction in transmission cost, with little perceptible loss of visual quality.
  • systems of this invention can provide
  • systems of this invention can provide 70% to 80% decrease in transmission costs, with little or no perceptible loss of visual quality compared to codec alone compression, transmission and decompression.
  • this invention provides a method for producing a video image of an object, comprising the steps: a. providing a digitized image frame of said object; b. providing a decimated WT of said digitized image frame; c. discarding high-frequency components of said decimated WT thereby producing a pre-processed frame; d. compressing said pre-processed frame using a video codec producing a compressed video frame; e. decompressing said compressed video frame using said codec; and f. recreating a full sized image of said frame using post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
  • a method of this invention provides after step d above, a step of transmitting said compressed image to a remote location.
  • this invention provides a method, further comprising displaying said full sized image on a video monitor.
  • this invention provides a method, wherein said step of preprocessing includes a single level frame size reduction according to the following steps:
  • ⁇ o Compute the decimated low-frequency Haar WT for consecutive pixels o Store in half the width of pFrameln the resulting values o At end of row, store the last pixel unchanged
  • this invention provides a method, further comprising a second level pre-processing step.
  • this invention provides a method, further comprising a second level step and a third level step of pre-processing.
  • this invention provides a method, wherein said step of postprocessing includes a first level frame size expansion according to the following steps:
  • this invention includes a method, further comprising the step of a second level frame size expansion.
  • this invention includes a method, further comprising a second level step and a third level step of frame size expansion.
  • this invention includes a method, wherein a codec is selected from the group consisting of MPEG-4, H264, VC-I, and DivX.
  • this invention includes a method, wherein said codec is a wavelet-based codec or any other kind of codec.
  • methods of this invention can provide high-quality video reproduction of video images in real time.
  • methods can provide over 50% reduction in storage space.
  • methods can provide over 50% reduction in transmission cost, with little perceptible loss of visual quality.
  • the reduction in storage space may be over 70% to 80%, with little reduction in video quality compared to codec-alone compression, transmission and decompression.
  • FIG. 1 shows a video compression system using the invention in conjunction with a video codec.
  • FIG. 2 shows a frame size reduction step of an embodiment of the invention that reduces the length of the columns and rows of an original frame by applying a decimated WT repeatedly level after level of reduction.
  • FIG. 3 shows an expansion of an embodiment of the invention of columns and rows to recover their original lengths level after level.
  • FIG. 4 shows a process of frame size reduction of an embodiment of the invention by the application of a low- frequency Haar Wavelet Filter to the rows and columns of a video frame.
  • FIG. 5 shows a process of an embodiment of the invention for recovering the original size of a video frame by the application of a recovery algorithm of this invention to a previously reduced frame.
  • FIG. 6 shows a process of an embodiment of the invention for reducing the frame size one more level compared to the process shown in FIG. 4.
  • FIG. 7 shows expansion by one-level of a two-level sized reduction of an embodiment of the invention.
  • the original full size can then be recovered by the process of FIG. 5.
  • FIG. 8 shows a process of an embodiment of the invention for going from 2-Level frame size reduction to 3 -Level frame size reduction.
  • FIG. 9 shows a process of an embodiment of this invention for frame size expansion from 3 -Level size reduction to 2-Level size reduction. Additional levels of expansion can be handled similarly.
  • FIG. 10 shows a photograph of a video frame, of 1080i video compressed by H264 to 6 Mbps and then decompressed and displayed.
  • FIG. 11 shows a photograph of the codec-processed image of the photograph shown in FIG. 10 compressed by H264 with pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
  • FIG. 12 shows a photograph of the frame shown in FIG. 10 compressed by H264 with pre-processing according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
  • FIG. 13 shows a photograph of a frame of 1080i video compressed by VC-I to 6 Mbps and then decompressed and displayed.
  • FIG. 14 shows a photograph of the same frame as in FIG. 13 compressed by VC- 1 after pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
  • FIG. 15 shows a photograph of the same frame as in FIG. 12 compressed by VC- 1 after pre-processing according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
  • FIG. 16 shows a photograph of a frame of 108Oi video compressed by H264 to 6 Mbps and then decompressed and displayed.
  • FIG. 17 shows a photograph of the frame shown in FIG. 16 compressed by H264 with pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
  • FIG. 18 shows a photograph of the same frame as shown in FIG. 16 compressed by H264 and pre-processed according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
  • FIG. 19 shows a photograph of a frame of 108Oi video compressed by H264 to 6 Mbps and then decompressed and displayed.
  • FIG. 20 shows a photograph of the same frame as in FIG. 19 compressed by H264 and pre-processed according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
  • FIG. 21 shows a photograph of the same frame as in FIG. 19 compressed by H264 and pre-processed according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
  • FIG. 22 shows a schematic diagram of a system of this invention to implement frame pre-processing and post-processing methods according to embodiments of this invention.
  • FIGs. 23A and 23B depict schematic drawings of pre-processing (FIG. 23A) and posts-processing (FIG. 23B) devices of this invention.
  • FIG. 24A and 24B depict schematic drawings of computer readable devices containing instructions for pre-processing (FIG. 24A) and post-processing (FIG. 24B) of this invention.
  • Embodiments of the invention involve taking the decimated WT of a given video frame down several levels and keeping only the low- frequency part at each level.
  • Embodiments of this invention include new systems and methods for decreasing the amount of space needed to store electronic files containing video images.
  • a frame of a video file is pre-processed by methods and systems of this invention to reduce its size by factors of 4, 16, 64 or even further.
  • a video codec is applied to compress the frame of significantly reduced size to produce a compressed file which is significantly smaller than the frame would be without the use of the frame pre-processing.
  • all frames of a video file can be processed in a similar fashion. Such compressed file can then be stored and/or transmitted before decompression.
  • the final step is to recover one or more individual video frames in their original size with comparable quality. This is accomplished by the second part of the invention which is used after a codec decompression step.
  • video image has the same meaning as "video frame”
  • image has the same meaning as "frame” when used in the context of video information.
  • frame pre-processing means processes where a video image or video frame is reduced in accordance with aspects of this invention prior to encoding (compression) by a codec.
  • frame post-processing means processes whereby an image decoded by a codec is further expanded according to methods of this invention to produce a high-quality image.
  • codec refers to a computerized method for coding and decoding information, and as applied to this invention, refers to a large number of different technologies, including MPEG-4, H-264, VC-I as well as wavelet-based methods for video compression/decompression disclosed in U.S. Patent No: 7,317,840, herein incorporated fully by reference.
  • computer readable medium or “medium” as applied to a storage device includes diskettes, compact disks (CDs) magnetic tape, paper, flash drive, punch cards or other physical embodiments containing instructions thereon that can be retrieved by a computer device and implemented using a special purpose computer programmed to operate according to methods of this invention.
  • a "non-physical medium” includes signals which can be received by a computer system and stored and implemented by a computer processor.
  • Embodiments of the present invention are described with reference to flowchart illustrations or pseudocode. These methods and systems can also be implemented as computer program products.
  • each block or step of a flowchart, pseudocode or computer code, and combinations of blocks (and/or steps) in a flowchart, pseudocode or computer code can be implemented by various means, such as hardware, firmware, and/or software including one or more computer program instructions embodied in computer-readable program code logic.
  • any such computer program instructions may be loaded onto a computer, including a general purpose computer or a special purpose computer, or other programmable processing apparatus to produce a machine, such that the computer program instructions which execute on the computer or other programmable processing apparatus implement the functions specified in the block(s) of the flowchart(s), pseudocode or computer code.
  • blocks of the flowcharts, pseudocode or computer code support combinations of methods for performing the specified functions, combinations of steps for performing the specified functions, and computer program instructions, such as embodied in computer-readable program code logic for performing the specified functions.
  • each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or combinations of special purpose hardware and computer-readable program code logic means.
  • these computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instructions which implement the function specified in the block(s) of the flowchart(s), pseudocode or computer code.
  • the computer program instructions may also be loaded onto a computer or other programmable processing apparatus to cause a series of operational steps to be performed on the computer or other programmable processing apparatus to produce a computer- implemented process such that the instructions which execute on the computer or other programmable processing apparatus provide steps for implementing the functions specified in the block(s) of the flowchart(s).
  • a feature is the ability to recreate a given image or video frame from the low-frequency component of its WT which can be 1 A, 1/16, 1/64 etc. the size of the original image or video frame. This can be done precisely by applying the mathematics of direct wavelet transformation (WT) and the computations described below.
  • WT direct wavelet transformation
  • the WT is applied to the individual pixel rows and columns of a given image or video frame. This is done separately for the luminance (Y) and chrominance (U, V) components of the different pixels of each row and column. It can also be done for the R, G and B planes.
  • the yjS values for the entire row or column can be found. Therefore, besides the XjS values, one more value, the very last value of the y;s, can also be stored to be able to recreate precisely the entire original row or column.
  • the additional memory required is very small overhead when one considers that we are dealing with hundreds or even thousands of pixels for each row and column of images or video frames of typical applications.
  • the size can be reduced to approximately 1 A of the original that can be reproduced exactly from its reduced version.
  • This process can be repeated on the reduced images or video frames for further size reductions of 1/16, 1/64, etc., of the original.
  • this cannot be done indefinitely because the precision of the calculations must be limited in order to avoid increasing the required number of bits instead of reducing it and some information is being lost at each 1 A reduction.
  • extensive tests showed that the quality of image reproduction is maintained up to 2 or 3 reduction levels with size reduction of up to 16 or 64 times before compression by the codec. Such levels of compression are very significant in terms of video storage and transmission costs.
  • Such tests consisted of using a number of diverse uncompressed video clips, i.e., sports, action movies, educational videos, etc, of about 10 minute duration and requiring tens of Gigabytes of storage space for each. Such video clips were then compressed by a number of different codecs as well as by the methods of the invention. The resulting compressed files were compared for size and then decompressed and played back side by side to compare the perceived quality. Such tests clearly demonstrated that methods of the invention can be suitable for providing additional substantial compression of files, and decompression of the files without significant loss of quality. Photographic examples of some of these tests are provided herein as FIGs. 10-21.
  • This step of the invention can produce high quality full-screen frames for display on a TV set or PC Monitor. Because of the amount of data involved, standard approaches can be very time-consuming and cannot produce high quality enlargements in any case.
  • the techniques developed to complete the frame expansion methods of the invention can be simple computationally, i.e., fast, and can generate enlarged images of high quality with no pixelization and showing none of the blocking artifacts that plague state-of-the-art techniques.
  • the methods of this invention can be applied repeatedly with similar results and enlargement factors of 4 every time it is applied.
  • the process can be further extended by using, after more than 2 or 3 reduction levels, any of the expansion filters disclosed in U.S. Patent No. 7,317,840 to enlarge very small images with high quality.
  • U.S. 7,317,840 is expressly incorporated fully by reference herein.
  • the image expansion technique disclosed in such a patent is based on the fact that the given image can be considered to be the level 1 low frequency component of the WT of a higher resolution image which is four times larger.
  • One way to accomplish this is to estimate the missing high frequency WT coefficients of level 1 from the given low frequency coefficients.
  • wavelets are functions generated from a single function ⁇ by dilations and translation.
  • j corresponds to the level of the transform, and hence governs the dilation
  • n governs the translation
  • the basic idea of the wavelet transform is to represent an arbitrary function f as a superposition of wavelets.
  • the wavelet transform coefficients are given by the inner product of the arbitrary function and the wavelet basis functions:
  • a mother wavelet ⁇ and a scaling function ⁇ .
  • the scaling function ⁇ generates a family of dilated and translated versions of itself:
  • is a function associated with the corresponding synthesis filter coefficients defined below.
  • h n and g n represent the low-pass analysis filter and the high-pass analysis filter respectively, and h n and g n represent the corresponding synthesis filters.
  • J (XV) J X J+1 - H J X J I I 2 + o I G> X J
  • G is the regularization operator and ⁇ is a positive scalar such that ⁇ — »0 as the accuracy of X J+1 increases.
  • Equation (15) may be also written with respect to the estimated wavelet transform coefficients
  • J (C x 0+0 , ⁇ ) I G 1 G X J+1 - H J G C x 0+0
  • the matrix T is not square, but rather, it is rectangular. Its dimensions are n ⁇ n/2 where n is the size of the data before any given level of transformation. This can be verified from the following sizes for the Wavelet Transform matrices: H and G are n/2 • n matrices and H and G are n • n/2. Notice that ⁇ l + G t H t H G is a square matrix of size n/2
  • Another aspect of this invention is the structure of the matrix T.
  • the rows of T are made up of just two short filters that repeat themselves every two rows with a shift to the right of one location. All other elements of the matrix T are zero. This means that every level of the Wavelet Transform can be recreated from the previous level (of half the size) by convolving both filters centered at a specific location of the available data with such data. This results in two new values from every given value thus doubling the size of the data at every level of signal decompression or expansion. There is no need to multiply the matrix T with the given vector.
  • the two filters depend on the coefficients of the wavelet filters used to transform the original data in the case of compression while any wavelet filter coefficients can be used to determine the two expansion filters. The most significant criteria being quality and speed.
  • the method is applied first to columns and then to rows. Also, for color images, the method is applied separately to the luminance (Y) and the chrominance (UV) components.
  • the procedures of the invention can be extended to other wavelets in addition to the Haar Wavelet, although the calculations are more complicated and time consuming.
  • the corresponding equations for the WT and IWT lead to a sparse system of linear equations in which only a small number of its matrix elements are nonzero, resulting in a band diagonal matrix in which the width of the band depends on the number of Wavelet coefficients.
  • the coefficients for the inverse wavelet transform are:
  • Z n-2 b 4 y 2n -6 + b 3 y2n-5 + b 2 y2n-4 + b
  • Example 1 Frame Reduction and Expansion Techniques
  • the application of the decimated Haar WT to a given video frame results in a frame that is ! ⁇ the original size because only the low-frequency Haar wavelet filter is applied. It has been proven above that the high-frequency Haar wavelet filter need not be applied if just the last original value before wavelet transformation of a row or column pixel is saved. With this information, all the preceding original pixels of a row or column can be calculated exactly.
  • This process can be repeated again on the resulting reduced frame for additional sized reduction to 1/16 of the original and so on. This process is described in detail below.
  • FIG. 4 depicts drawing 400 showing a one-level frame size reduction to 1 A of its original size according to an embodiment of this invention.
  • Frame A 410 has horizontal dimension x and vertical dimension y.
  • Column LC415 and row LR420 are identified, and pixel (X) 425 is shown.
  • First step 426 is horizontal frame reduction, producing Frame B 430, having horizontal dimension x/2 and vertical dimension y.
  • Column (LC) 435 and row (LR/2) 440 are identified, as is pixel X 445.
  • Second step 446 is vertical frame reduction, producing Frame C 450, having horizontal size x/2 and vertical size y/2.
  • Column (LC/2) 455, row (LR/2) 460 and pixel (X) 465 are identified.
  • A is the original frame with dimensions x and y.
  • the decimated low- pass Haar WT is applied to A horizontally, resulting in a frame "B" of dimensions (x/2) and y.
  • the last column of A i.e., (“LC")
  • LC decimated low-pass Haar WT
  • C frame "C” of dimensions (x/2) +1 and (y/2).
  • the last row of B i.e., ("LR/2"
  • LR/2 is copied to the last row of C, i.e., y/2 + 1.
  • a frame pre-processing size reduction process of an embodiment of the invention is applied to the original frames of a given video file. Then, a codec is applied to each frame in the given video file.
  • Application of methods of this invention produces a much smaller file than without the frame pre-processing size reduction step.
  • the resulting compressed video file of this invention can then be stored and/or transmitted at a greatly reduced cost.
  • ⁇ o Compute the decimated low-frequency Haar WT for consecutive pixels o Store in half the width of pFrameln the resulting values o At end of row, store the last pixel unchanged
  • an implementation of a second level step includes the additional instruction:
  • Using a second level step reduces the size of the frame to 1/16 of the original size.
  • an implementation of a third level step includes the additional instruction:
  • Using a third level step reduces the size of the frame to 1/64 of the original size.
  • the computation of the decimated low-frequency Haar WT simply involves taking the average of two consecutive pixels, i.e., the average of each of their components (Y, U, V or R, G, B), and making such average the value of the WT in the corresponding position as we move along the rows of the image first and then down the columns of the WT of the rows.
  • This WT of the original image results in a new image that looks very much like the original but at ! ⁇ its size.
  • This one level post-processing step increases the size of the frame by 4-fold compared to the input frame size.
  • an embodiment of this invention includes the following step:
  • an embodiment of this invention further includes the step: • Repeat with pFrameOut of the previous level being the input of this level. This produces a frame that is 64-fold larger than the original input frame.
  • the resulting pFrameOut is an almost identical reproduction of the original image before the frame pre-processing step of size reduction because of the formulas of the invention used in the computation of the new pixels.
  • the codec is applied for decompression and then the above frame post-processing or size expansion procedure of an embodiment of the invention is used prior to displaying high-quality video in its original full-size.
  • FIG. 5 depicts a drawing 500 showing a one-level frame size expansion according to an embodiment of this invention.
  • Reduced Frame C 510 has horizontal size x/2+l and vertical size y/2+1.
  • Frame C 510 has Column 515 and Row 520, with pixel (X) 525 shown.
  • Vertical expansion step 526 produces Frame B 530, having a horizontal dimension x/2+l and vertical dimension y.
  • Column (LC) 535 is identified.
  • Horizontal expansion step 536 produces Frame A 540 having horizontal dimension x and vertical dimension y as in the original frame.
  • FIGs. 4 and 5 can be continued by one or more levels starting with the C frame instead of the A frame. There are additional right columns and bottom rows to be saved but they are one half the sizes of the previous level and, consequently, they don't appreciably detract from the saving in storage and transmission bandwidth.
  • FIG. 6 depicts a drawing 600 of a two-level size reduction according to an embodiment of this invention including another level of frame reduction compared to FIG. 4.
  • frame C 610 has horizontal dimension x/2+l and vertical dimension y/2+1.
  • Columns (LC2) 620 and (LCl/2) 615 are identified.
  • Rows (LR2) 630 and (LR1/2) 625 are also identified.
  • Pixels (X) 635 and (Y) 640 are identified.
  • By application of size reduction step 636 in the horizontal dimension frame D 650 is produced, having horizontal dimension x/4 and vertical dimension y/2.
  • Columns (LC2) 620 and (LC 1/2) 615 are identified, as are rows (LR2/2) 645 and (LR1/4) 650.
  • Pixels (X) 637, (Y) 642 and (Z) 655 are shown. With size reduction step 638 in the vertical direction, frame E 660 is produced, having horizontal dimension x/4 and vertical dimension y/4. Columns (LC2/2) 665 and (LC 1/4) 670, rows (LR2/2) 645 and (LR1/4) 650 are shown. Pixels (X) 675, (Y) 680, (Z) 685 and (W) 690 are also shown.
  • FIG. 7 depicts drawing 700 of a one-level expansion of a two-level reduction according to an embodiment of this invention.
  • Frame E 710 has horizontal dimension x/4 and vertical dimension y/4.
  • Columns 720 and 725, Rows 730 and 735, and pixels (X) 740, (Y) 745, (Z) 750 and (W) 755 are shown.
  • Application of frame expansion step 756 in the vertical dimension produces frame F 760 having horizontal dimension x/4 and vertical dimension y/2.
  • Columns 765 and 770, Row 775, and Pixels (X) 780 and (Z) 785 are shown.
  • frame G 790 is produced having horizontal dimension x/2 and vertical dimension y/2.
  • FIG. 8 depicts drawing 800 of a three-level size reduction according to an embodiment of this invention.
  • Frame E 810 has horizontal dimension x/4 and vertical dimension y/4.
  • Columns 812 and 814, Rows 816 and 818, and Pixels (X) 820, (Y) 822, (Z) 824 and (W) 826 are shown.
  • frame H 830 is produced, having horizontal dimension x/8 and vertical dimension ⁇ //.
  • Columns 832, 834 and 836, Rows 838 and 840, and Pixels (X) 842, (Y) 844, (Z) 846, (W) 848, (R) 850 and (S) 852 are shown.
  • FIG. 9 depicts drawing 900 of a one-level frame expansion of a three-level frame reduction according to an embodiment of this invention.
  • Frame I 910 has horizontal dimension x/8 and vertical dimension y/8.
  • Columns 912, 913 and 914, and Rows 915, 916 and 917 are shown.
  • Pixels (X) 918, (W) 919, (V) 926, (U) 922, (Y) 921, (Z) 920, (T) 923, (R) 924 and (S) 925 are shown.
  • Application of frame expansion step 927 in the vertical dimension produces frame J 930.
  • Frame J 930 has horizontal dimension x/8 and vertical dimension >/4.
  • Columns 931, 932 and 933, and Rows 934 and 935, and Pixels (X) 936, (W) 937, (Y) 939, (Z) 938, (R) 940 and (S) 941 are shown.
  • Application of frame expansion step 945 in the horizontal dimension produces frame K 950.
  • Frame 950 has horizontal dimension x/4 and vertical dimension y/4.
  • Columns 951 and 952, Rows 953 and 954, and Pixels (X) 955, (W) 956, (Y) 957 and (Z) 958 are shown.
  • This Example provides one specific way in which the principles of this invention can be implemented to pre-process frames in the horizontal and vertical dimensions to reduce their size prior to compression and decompression using a codec.
  • Table 2 below presents working examples of video compression improvements of some widely used standard video codecs through application of methods of this invention, without loss of video quality for any given codec. Note that the methods of this invention are applicable to HD 108Oi and 108Op videos, HD 72Op videos, and SD480i videos, as examples, as well as any other formats.
  • Example 7 Further Levels of Size Reduction and Expansion with Wavelet-based Methods
  • the results described in Examples 4 through 6 can be further improved by additional levels of frame size reduction by using for expansion to the previous level any of the filters obtained from the calculations disclosed in US Patent 7,317,840.
  • the two resulting filters -0.0575 1.1151 -0.0575 0.0 and -0.0912 0.591 0.591 -0.0912 are convolved consecutively with the rows of a given image or frame to convert every pixel to two pixels of each new expanded row. The process is then repeated vertically column by column to obtain an expanded frame that is four times larger than the original frame.
  • other wavelet based expansion filters can be used, for example, the expansion filters of Table 1.
  • Such wavelet-based filters can be applied to the data of Table 2 to further reduce the video file sizes to about 1/8 and about 1/16 of the size produced by any of the codecs of the Table 2 with little or no perceptible loss in video quality.
  • the size reductions of video files compressed using the techniques of this invention are about 1 A, ⁇ ⁇ , 1 A (depending on the level of size reduction) of the compressed files using the codecs alone.
  • the perceived qualities of the decompressed videos for the different reduction levels are indistinguishable from that of the decompressed videos produced by the codec alone for all the codecs.
  • FIGs. 10 through 21 show examples of frame quality produced by a given codec and by the same codec enhanced by pre-processing and post-processing according to methods of this invention. Any differences in quality are clearly imperceptible.
  • FIGs. 10 through 21 are arranged in sets of three each, wherein the first figure of each set (i.e., FIG. 10, FIG. 13, FIG. 16, and FIG. 19 represent photographs of video frames that have been compressed using only a codec to a compression of 6 Mbps.
  • FIG. 11, FIG. 14, FIG. 17 and FIG. 20 represent photographs of video frames shown in FIGs. 10, 13, 16 and 19, respectively, that have been pre-processed using methods of this invention, then compressed by the codec, decompressed by the codec and finally post-processed using methods of this invention to provide a compression to 3 Mbps.
  • FIG. 12, FIG. 15, FIG. 18, and FIG. 21 represent photographs of video frames shown in FIGs. 10, 13, 16 and 19, respectively, that have been pre-processed using methods of this invention, then compressed by the codec, decompressed by the codec and finally post-processed using methods of this invention to provide a compression to 1.5 Mbps.
  • FIG. 22 depicts a schematic drawing 2200 of a computer-based system for implementing frame pre-processing, codec compression and decompression, and frame post-processing of this invention.
  • An image of Object 2210 is captured as Frame 2214 by Camera 2212.
  • Frame 2214 is transferred at step 2216 to First Device 2220, which contains Buffer 2225 to store Frame 2214, Memory Device 2230 containing instructions for pre-processing and Pre-Processing Module 2235.
  • Frame 2214 is transferred to Pre- Processing Module 2235, and pre-processing steps 2232 of this invention are carried out in Pre-Processing Module 2235, thereby producing a pre-processed frame.
  • the pre- processed frame is transferred to Codec Compression Module 2240, where the pre- processed frame is compressed.
  • the compressed frame is transferred at step 2243 to Receiver 2245, containing Codec Decompression Module 2250, where the compressed frame is decompressed.
  • the decompressed frame is transferred at step 2253 to Device 2260, which contains Memory Device 2270 containing instructions for post-processing.
  • Device 2260 also contains Post-Processing Module 2265, where the decompressed frame is post-processed according to embodiments of this invention.
  • the post-processed frame may be stored in buffer 2275 or transferred directly via step 2277 to Display Monitor 2280, where Post-Processed Image 2290 is displayed.
  • FIG. 22 also shows that optionally, the compressed frame is transferred at step 2244 to Receiver 2246, containing Storage Device 2251, where the compressed frame is kept for further use.
  • the frame is transferred at step 2254 to device 2245 where it is processed as described above.
  • similar systems can be constructed in which different codecs are incorporated, each of which receives a pre-processed frame according to methods of this invention, but which are compressed and decompressed using the particular codec. Then, after decompression, post-processing of this invention can be accomplished such that the monitor devices of different systems display images that are similar in quality to each other.
  • FIG. 23A depicts a schematic diagram 2300 of Pre-Processing Device 2301 of this invention.
  • Pre-Processing Device 2301 contains a Memory Area 2302 containing instructions for pre-processing, and Processor 2303 for carrying out instructions contained in Memory Area 2302.
  • Such combined memory and pre-processing devices may be integrated circuits that can be manufactured separately and then incorporated into video systems.
  • Connection of Pre-Processing Device 2301 into a video system is indicated at Input 2304, where a frame from an image capture device (e.g., camera) can be input into Pre-Processing Device 2301.
  • Output of the Pre-Processing Device 2301 is shown at Output 2305, which can be connected to a codec (not shown).
  • a buffer area may be included in Pre- Processing Device 2301.
  • FIG. 23B depicts a schematic diagram 2320 of Post-Processing Device 2321 of this invention.
  • Post-Processing Device 2321 contains a Memory Area 2322 containing instructions for post-processing according to methods of this invention, and also includes Processor 2323 for carrying out instructions contained in Memory Area 2322.
  • Such combined memory and post-processing devices may be integrated circuits that can be manufactured separately and then incorporated into video systems. Connection of Post-Processing Device 2321 to a video system is indicated at Input 2324, where a decompressed frame from a codec (not shown) can be input into Post-Processing Device 2321.
  • Output of the Post-Processing Device 2321 is shown at Output 2325, which can be attached to an output device, such as a video monitor (not shown).
  • an output device such as a video monitor (not shown).
  • a buffer area (not shown) may be included in Post-Processing Device 2321.
  • Example 11 Computer-Readable Devices Containing Instructions for Pre- Processing and Post-Processing
  • FIG. 24A depicts a schematic drawing 2400 of an embodiment of a computer readable device 2401 of this invention.
  • Device 2401 contains Memory Area 2402, which contains instructions for frame pre-processing according to methods of this invention.
  • Such a device may be a diskette, flash memory, tape drive or other hardware component.
  • Instructions contained on Device 2401 can be transferred at step 2403 to an external preprocessor (not shown) for execution of the instructions contained in Memory Area 2402.
  • FIG. 24B depicts a schematic drawing 2420 of an embodiment of a computer readable device 2421 of this invention.
  • Device 2421 contains Memory Area 2422, which contains instructions for frame post-processing according to methods of this invention.
  • Such a device may be a diskette, flash memory, tape drive or other hardware component.
  • Instructions contained on Device 2421 can be transferred at step 2423 to an external postprocessor (not shown) for execution of the instructions contained in Memory Area 2422.
  • Systems and methods of this invention can be used in the telecommunications and video industries to permit high-quality video to be stored, transmitted and replayed at reduced cost and with reduced requirements for computer storage capacity.
  • the implications of aspects of this invention for the reduction of the current staggering costs of video storage and transmission are significant.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

Embodiments of this invention include mathematical methods to develop software and/or hardware implementations that use wavelet transforms (WT) to pre-process video frames that can then be compressed using a variety of codecs to produce compressed video frames. Such compressed video frames can then be transmitted, decompressed, post-processed using the post-processing methods disclosed in the invention and displayed in their original size and quality using software and/or hardware implementations of embodiments of the invention, thereby producing real-time high-quality reproduction of video sequences. Embodiments include computer devices and computer readable media to implement these methods.

Description

SYSTEMS AND METHODS FOR COMPRESSION TRANSMISSION AND DECOMPRESSION OF VIDEO CODECS
Claim of Priority: This PCT International Application claims priority to United States Provisional
Patent Application No: 61/190,585, filed August 29, 2008, entitled: "Improved Methods for Compression Transmission and Decompression of Video Codecs," Angel DeCegama inventor.
Copyright Notice
This application contains material that is subject to protection under copyright laws of the United States (18 U.S. C.) and other countries.
FIELD OF THE INVENTION This invention relates to the field of video compression when it is desired to minimize the amount of bytes needed to reproduce the different video frames with a desired visual quality while reducing the corresponding costs of storage and transmission. Particularly, this invention relates to wavelet transformation methods to improve the performance of any video codec to compress and decompress video frames.
BACKGROUND
Video communications systems are being swamped by increasing amounts of data and current video compression techniques have remained almost stagnant in recent years. New techniques are needed to significantly cut the video data storage and transmission requirements.
SUMMARY
Although video compression, transmission, decompression and display technologies have been under rapid development, many of the methods used are applicable to only a few types of video technologies. Thus, a new problem in the field is how to develop compression and decompression methods that are widely applicable to a variety of video codecs so that computer storage and transmission requirements are minimzed. To solve this and other problems, I have discovered and developed new methods for rapid compression, decompression and display that are applicable to a wide range of video codecs that significantly reduce computer storage and transmission requirements which maintaining high-quality video output, so that movies, entertainment, live television, and the like can be viewed in real time.
In some embodiments of this invention, it is possible to reduce data storage and transmission requirements by 50% for a given information content and user quality of service. In other embodiments, reductions of over 70% can be easily achieved, compared to the codec-alone level of compression. Such advantageous effects can be obtained with little or not appreciable loss of visual quality.
These embodiments of this invention solve important problems in video transmission and storage without any disruption of existing video compression codecs and can be applied without the need for special handling of a codec. Certain embodiments of this invention simply enhance the function of existing codecs by making them perform better with computer-based methods to process each frame before being compressed and after being decompressed. It is not a disruptive technology. It is simply an enabling technology. Aspects of this invention are based on the mathematics of the Wavelet Transform (WT).
Embodiments of the invention involve pre-processing a video image, decimating the image using WT, taking the decimated WT of a given video frame down several levels and keeping only the low-frequency part at each level. An example of such a
"reduction method" is described herein below. Then, a video codec operates in its usual fashion on such a "pre-processed frame" or "reduced frame" to compress the image and further decrease the amount of information that is needed to be stored and transmitted. Then, the data representing the pre-processed frame compressed using a codec can be transmitted with high efficiency because the number of bits of information has been reduced substantially compared to either the original frame, or the frame that had been processed by the codec alone.
FIG. 1 depicts a schematic drawing 100a of a method of this invention. Input Video File 10 is received by a computer input device, and is then pre-processed by Size
Reduction method 20 of this invention to produce a Reduced Video File 30. Reduced
Video File 30 is then processed by Codec 40a, thereby producing Compressed Video File
50. Then, Codec 40b decompresses Compressed Video File 50 to produce Decompressed Video File 60 being 1A, 1/16, 1/64 etc. of the original size of Input Video File 10. Application of a post-processing method of Frame Expansion 70 produces Output Video File 80 having a full size image which is then displayed on video monitor 90 or is stored in a memory device 100. Optionally, Transmission Process 55 can transmit Compressed Video File 50 to a remote location, where it can be decompressed by the codec and post- processed according to methods of this invention, and displayed on a video monitor or stored for future use.
FIG. 2 depicts a general schematic drawing 200 showing how an original frame is reduced using frame pre-processing methods of this invention. Original Frame 210 is first treated to decimate low frequency (LF) components of the WT 220, which are kept. High frequency (HF) components 230 are discarded. Then, 220 is then further pre- processed in step 235, again decimating low frequency (LF) components of the WT 240, which are kept. High frequency (HF) components 250 are discarded. The process can be repeated as desired through 3, 4, 5, 6, or even more levels. FIG. 3 depicts a general schematic drawing 300 showing frame size expansion according to an embodiment of this invention. Reduced Size 310, is vertically expanded in step 315, thereby producing Vertically Expanded Frame 320, which is then horizontally expanded in step 325 producing Horizontally Expanded Frame 330. Horizontally Expanded Frame 330 is vertically expanded in step 335 thereby producing Vertically Expanded 340, which is horizontally expanded in step 345, thereby producing Horizontally Expanded Frame 350. The process can be repeated as many times as desired through 3, 4, 5, 6 or more levels.
Pre-processing methods of this invention can result in a size reduction for the frame of 1A for one level of transformation or 1/16 for two levels of transformation, and so on. This can be done for all frames in a given video sequence. Then the reduced frames are used to create a new video file, for example, in .avi format. It can be appreciated that other file formats can also be used, including for example, OG3, Asf, Quick Time, Real Media, Matroska, DIVX and MP4. This file is then input to any available codec of choice and it is compressed by the codec following its standard procedure to a size which typically ranges from 40% (one level of WT) to less than 20% (two levels or more of WT) of the compressed size obtained without the step of frame size reduction. Such files can be stored and/or transmitted with very significant cost savings. By appropriately interfacing with the codec, such procedure can be carried out frame by frame instead of having to create an intermediate file.
For decompression of each frame, the codec is used in its normal way and a file
(for example, in .avi format) of a size approximately equal to 1A (one level of WT) or 1/16, 1/64, etc. (two levels or more of WT) of the original uncompressed file size is obtained. The final step is to generate a file where all the frames are full size with the file size being the same as that of the original uncompressed file. The methods and systems to accomplish that without loss of quality with respect to the decompressed frames produced by the codec without the initial frame size reduction are described herein. This step can be accomplished frame by frame without producing the intermediate file, further improving the efficiency of the process.
It can be appreciated that a series of frames can be pre-processed, compressed, transmitted, decompressed, post-processed and displayed in real time, thereby producing a high quality video, such as a movie or live broadcast. Because the steps in pre- processing, compression, decompression, post-processing can be carried out very rapidly, a reproduced video (e.g., a movie or live broadcast), can be viewed in real time.
Thus, in certain aspects, this invention provides a system for video image compression and decompression, comprising: a first computer module for image frame pre-processing using direct wavelet transformation (WT); a video codec; a second computer module for image frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT and an output device.
In other aspects, this invention provides a system wherein said first computer module comprises: an input buffer for storing a video image frame; a memory device storing instructions for frame pre-processing, wherein said instructions are based upon direct wavelet transformation (WT); a processor for implementing said instructions for frame pre-processing, and an output. In further aspects, this invention includes systems wherein said second computer module comprises: an input buffer; a memory device storing instructions for frame post-processing, wherein said instructions are based upon using low-frequency parts of the WT plus the last pixel of every row and column of the original image before the WT; a processor for implementing said instructions for frame post-processing; and an output.
In still further aspects, this invention provides systems further comprising another storage device for storing a post-processed frame of said video image.
In other aspects, a system of this invention includes instructions for frame preprocessing using decimated WT and retaining low frequency part of said decimated WT and discarding high-frequency part of the decimated WT.
In still other aspects, a system of this invention includes instructions for frame post-processing to recreate a post-processed frame by using low- frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
In other aspects a system of this invention includes instructions for frame postprocessing to recreate a full sized post-processed frame by using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT. In further aspects, this invention provides an integrated computer device for preprocessing a video image frame, comprising: a computer storage module containing instructions for frame pre-processing according to decimated WT; and a processor for processing said decimated WT by retaining low-frequency parts and discarding high-frequency parts.
In additional aspects, this invention provides an integrated computer device for post-processing a video image frame, comprising: a computer storage module containing instructions for frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT; and a processor for processing said computations to re-create a full-size video image.
In still further aspects, this invention provides a computer readable medium, comprising: a medium; and instructions thereon to pre-process a video frame using WT.
In still additional aspects, this invention provides a computer readable medium, comprising: a medium; and instructions thereon to post-process a reduced video frame to re-create a video frame of original size using low-frequency parts of the WT plus the last pixel of every row and column of the original image before the WT.
In certain of these above aspects, a computer readable medium is a diskette, compact disk (CD), magnetic tape, paper or punch card.
In aspects of this invention, the Haar WT is used.
In other aspects of this invention Daubechies - 4, Daubechies - 6, Daubechies - 8, biorthogonal or asymmetrical wavelets can be used.
Systems of this invention can provide high-quality reproduction of video images in real time. In some aspects, systems can provide over 50% reduction in storage space.
In other aspects, systems can provide over 50% reduction in transmission cost, with little perceptible loss of visual quality. In other aspects, systems of this invention can provide
70% to 80% reduction in storage costs. In additional aspects, systems of this invention can provide 70% to 80% decrease in transmission costs, with little or no perceptible loss of visual quality compared to codec alone compression, transmission and decompression.
In other aspects, this invention provides a method for producing a video image of an object, comprising the steps: a. providing a digitized image frame of said object; b. providing a decimated WT of said digitized image frame; c. discarding high-frequency components of said decimated WT thereby producing a pre-processed frame; d. compressing said pre-processed frame using a video codec producing a compressed video frame; e. decompressing said compressed video frame using said codec; and f. recreating a full sized image of said frame using post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT. In other aspects, a method of this invention provides after step d above, a step of transmitting said compressed image to a remote location.
In still other aspects, this invention provides a method, further comprising displaying said full sized image on a video monitor. In further aspects, this invention provides a method, wherein said step of preprocessing includes a single level frame size reduction according to the following steps:
For every row in input frame pFrameln
{ o Compute the decimated low-frequency Haar WT for consecutive pixels o Store in half the width of pFrameln the resulting values o At end of row, store the last pixel unchanged
}
For every 2 consecutive rows in modified pFrameln { o Compute the decimated low frequency Haar WT of corresponding pixels in the 2 rows column by column o Store the resulting values in output frame pFrameOut o Advance row position by 2 }
Store the last row of the modified pFrameln in pFrameOut last row.
In certain of these aspects, this invention provides a method, further comprising a second level pre-processing step.
In other of these aspects, this invention provides a method, further comprising a second level step and a third level step of pre-processing.
In additional aspects, this invention provides a method, wherein said step of postprocessing includes a first level frame size expansion according to the following steps:
Copy last row of input frame pFrameln into intermediate output frame Img with the same pixels per row as pFrameln and double the number of rows.
For each pixel position of pFrameln and Img
{ o Calculate the new pixel values of 2 rows of Img starting at the bottom and moving up column by column according to the formulas
Figure imgf000008_0001
(the x's represent pixels of pFrameln and the y's represent pixels of Img) o Store the calculated pixels in Img
}
For every row of Img o Start with the last pixel and store it in the last pixel of the corresponding row of the output frame pFrameOut o Compute the pixels of the rest of the row from right to left according to the above formulas where now the x' s represent the pixels of Img and the y's represent the pixels of pFrameOut o Store the calculated pixels in pFrameOut }
In certain of these aspects, this invention includes a method, further comprising the step of a second level frame size expansion.
In other of these aspects, this invention includes a method, further comprising a second level step and a third level step of frame size expansion.
In certain embodiments, this invention includes a method, wherein a codec is selected from the group consisting of MPEG-4, H264, VC-I, and DivX.
In other embodiments, this invention includes a method, wherein said codec is a wavelet-based codec or any other kind of codec.
In certain aspects, methods of this invention can provide high-quality video reproduction of video images in real time. In some aspects, methods can provide over 50% reduction in storage space. In other aspects, methods can provide over 50% reduction in transmission cost, with little perceptible loss of visual quality. In other aspects, the reduction in storage space may be over 70% to 80%, with little reduction in video quality compared to codec-alone compression, transmission and decompression.
There are a multitude of applications for video compression in areas such as security, distant learning, videoconferencing, entertainment and telemedicine.
BRIEF DESCRIPTION OF THE FIGURES
This invention is described with reference to specific embodiments thereof. Other features of this invention can be appreciated in view of the Figure, in which: FIG. 1 shows a video compression system using the invention in conjunction with a video codec.
FIG. 2 shows a frame size reduction step of an embodiment of the invention that reduces the length of the columns and rows of an original frame by applying a decimated WT repeatedly level after level of reduction. FIG. 3 shows an expansion of an embodiment of the invention of columns and rows to recover their original lengths level after level.
FIG. 4 shows a process of frame size reduction of an embodiment of the invention by the application of a low- frequency Haar Wavelet Filter to the rows and columns of a video frame.
FIG. 5 shows a process of an embodiment of the invention for recovering the original size of a video frame by the application of a recovery algorithm of this invention to a previously reduced frame.
FIG. 6 shows a process of an embodiment of the invention for reducing the frame size one more level compared to the process shown in FIG. 4.
FIG. 7 shows expansion by one-level of a two-level sized reduction of an embodiment of the invention. The original full size can then be recovered by the process of FIG. 5.
FIG. 8 shows a process of an embodiment of the invention for going from 2-Level frame size reduction to 3 -Level frame size reduction.
FIG. 9 shows a process of an embodiment of this invention for frame size expansion from 3 -Level size reduction to 2-Level size reduction. Additional levels of expansion can be handled similarly.
FIG. 10 shows a photograph of a video frame, of 1080i video compressed by H264 to 6 Mbps and then decompressed and displayed.
FIG. 11 shows a photograph of the codec-processed image of the photograph shown in FIG. 10 compressed by H264 with pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
FIG. 12 shows a photograph of the frame shown in FIG. 10 compressed by H264 with pre-processing according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
FIG. 13 shows a photograph of a frame of 1080i video compressed by VC-I to 6 Mbps and then decompressed and displayed.
FIG. 14 shows a photograph of the same frame as in FIG. 13 compressed by VC- 1 after pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed. FIG. 15 shows a photograph of the same frame as in FIG. 12 compressed by VC- 1 after pre-processing according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
FIG. 16 shows a photograph of a frame of 108Oi video compressed by H264 to 6 Mbps and then decompressed and displayed.
FIG. 17 shows a photograph of the frame shown in FIG. 16 compressed by H264 with pre-processing according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
FIG. 18 shows a photograph of the same frame as shown in FIG. 16 compressed by H264 and pre-processed according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed.
FIG. 19 shows a photograph of a frame of 108Oi video compressed by H264 to 6 Mbps and then decompressed and displayed.
FIG. 20 shows a photograph of the same frame as in FIG. 19 compressed by H264 and pre-processed according to an embodiment of this invention to 3 Mbps and then decompressed, post-processed and displayed.
FIG. 21 shows a photograph of the same frame as in FIG. 19 compressed by H264 and pre-processed according to an embodiment of this invention to 1.5 Mbps and then decompressed, post-processed and displayed. FIG. 22 shows a schematic diagram of a system of this invention to implement frame pre-processing and post-processing methods according to embodiments of this invention.
FIGs. 23A and 23B depict schematic drawings of pre-processing (FIG. 23A) and posts-processing (FIG. 23B) devices of this invention. FIG. 24A and 24B depict schematic drawings of computer readable devices containing instructions for pre-processing (FIG. 24A) and post-processing (FIG. 24B) of this invention.
DETAILED DESCRIPTION
Aspects of this invention are based on the mathematics of the Wavelet Transform (WT). Embodiments of the invention involve taking the decimated WT of a given video frame down several levels and keeping only the low- frequency part at each level.
Embodiments of this invention include new systems and methods for decreasing the amount of space needed to store electronic files containing video images. In certain embodiments, a frame of a video file is pre-processed by methods and systems of this invention to reduce its size by factors of 4, 16, 64 or even further. Then a video codec is applied to compress the frame of significantly reduced size to produce a compressed file which is significantly smaller than the frame would be without the use of the frame pre-processing. In some embodiments, all frames of a video file can be processed in a similar fashion. Such compressed file can then be stored and/or transmitted before decompression. The final step is to recover one or more individual video frames in their original size with comparable quality. This is accomplished by the second part of the invention which is used after a codec decompression step. As used herein the term "video image" has the same meaning as "video frame," and the term "image" has the same meaning as "frame" when used in the context of video information.
As used herein, the terms "frame pre-processing," "frame size preprocessing" and "frame size reduction" mean processes where a video image or video frame is reduced in accordance with aspects of this invention prior to encoding (compression) by a codec.
As used herein, the terms "frame post-processing," "frame size post-processing" and "frame expansion" mean processes whereby an image decoded by a codec is further expanded according to methods of this invention to produce a high-quality image.
The term "codec" refers to a computerized method for coding and decoding information, and as applied to this invention, refers to a large number of different technologies, including MPEG-4, H-264, VC-I as well as wavelet-based methods for video compression/decompression disclosed in U.S. Patent No: 7,317,840, herein incorporated fully by reference.
The term "computer readable medium" or "medium" as applied to a storage device includes diskettes, compact disks (CDs) magnetic tape, paper, flash drive, punch cards or other physical embodiments containing instructions thereon that can be retrieved by a computer device and implemented using a special purpose computer programmed to operate according to methods of this invention. A "non-physical medium" includes signals which can be received by a computer system and stored and implemented by a computer processor.
Embodiments of the present invention are described with reference to flowchart illustrations or pseudocode. These methods and systems can also be implemented as computer program products. In this regard, each block or step of a flowchart, pseudocode or computer code, and combinations of blocks (and/or steps) in a flowchart, pseudocode or computer code can be implemented by various means, such as hardware, firmware, and/or software including one or more computer program instructions embodied in computer-readable program code logic. As will be appreciated, any such computer program instructions may be loaded onto a computer, including a general purpose computer or a special purpose computer, or other programmable processing apparatus to produce a machine, such that the computer program instructions which execute on the computer or other programmable processing apparatus implement the functions specified in the block(s) of the flowchart(s), pseudocode or computer code. Accordingly, blocks of the flowcharts, pseudocode or computer code support combinations of methods for performing the specified functions, combinations of steps for performing the specified functions, and computer program instructions, such as embodied in computer-readable program code logic for performing the specified functions. It will also be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or combinations of special purpose hardware and computer-readable program code logic means.
Furthermore, these computer program instructions, such as embodied in computer-readable program code logic, may also be stored in a computer-readable memory that can direct a computer or other programmable processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instructions which implement the function specified in the block(s) of the flowchart(s), pseudocode or computer code. The computer program instructions may also be loaded onto a computer or other programmable processing apparatus to cause a series of operational steps to be performed on the computer or other programmable processing apparatus to produce a computer- implemented process such that the instructions which execute on the computer or other programmable processing apparatus provide steps for implementing the functions specified in the block(s) of the flowchart(s). Embodiments of the Invention
In embodiments of this invention, a feature is the ability to recreate a given image or video frame from the low-frequency component of its WT which can be 1A, 1/16, 1/64 etc. the size of the original image or video frame. This can be done precisely by applying the mathematics of direct wavelet transformation (WT) and the computations described below.
Take, for example, the Haar wavelet. The direct Haar WT low-frequency coefficients are a2 = 0.5 and ai = 0.5 and the high-frequency coefficients are b2 = 0.5 and bi = -0.5. The IWT low-frequency coefficients are aa2 = 1.0 and aai = 1.0 and the IWT high-frequency coefficients are bb2 = -1.0 and bbi = 1.0. The WT is applied to the individual pixel rows and columns of a given image or video frame. This is done separately for the luminance (Y) and chrominance (U, V) components of the different pixels of each row and column. It can also be done for the R, G and B planes.
Let's define a set of y;s to constitute the different values of one such component of a given row or column of an image or video frame. Let's also define a set of XjS to be the corresponding WT low-frequency values and a set pf z;s to be the corresponding WT high-frequency values.
We can then write for the Haar WT (with decimation and no wraparound):
X0 = a2y0 + aiyi Z0 = b2y0 + biyi
Xi = a2y2 + aiy3 Zi = b2y2 + biy3
Xn = a2y2n + aiy2n+i Zn = b2y2n + biy2n+i
Knowing both the XjS and the ZjS we can reconstruct exactly the yis by calculating the corresponding IWT.
yo = aa2x0 + bb2z0 = X0 - Z0 yi = aaixi + bbiZ) = xi + zi y2 = aa2xt + bb2zi = xi - Z| y3 = aaix2 + bbiz2 = X2 + Z2
V2n = aa2xn + bb2zn = Xn - Zn y2n+i = aaixn+ι + bbiZn+i = xn+i + Zn+1 Assuming that y2n+i is known, we can then write:
y∑n = Xn - b2y2n - biy2n+i = Xn - 0.5y2n + 0.5y2n+i
and
y2n = Xn + 0-5*V2n±l = 2xn + VTn+i
1.5 1.5 3
Similarly, we can keep moving back towards yo.
y2n-i = Xn + Zn = Xn + b2y2n + biy2n+i
Figure imgf000015_0001
Figure imgf000015_0002
yi = 4X1 - Y1 3 yo = 2XOjLy-I
3 Similar equations can be obtained by moving from top to bottom and from left to right.
In other words, given the XjS that are the low-frequency values of the decimated Haar WT of the y,s, and given the very last value of the yiS of a row or column of the original image or video frame the yjS values for the entire row or column can be found. Therefore, besides the XjS values, one more value, the very last value of the y;s, can also be stored to be able to recreate precisely the entire original row or column. The additional memory required is very small overhead when one considers that we are dealing with hundreds or even thousands of pixels for each row and column of images or video frames of typical applications. By applying such a procedure to every row and column of an image or video frame, the size can be reduced to approximately 1A of the original that can be reproduced exactly from its reduced version. This process can be repeated on the reduced images or video frames for further size reductions of 1/16, 1/64, etc., of the original. Of course, this cannot be done indefinitely because the precision of the calculations must be limited in order to avoid increasing the required number of bits instead of reducing it and some information is being lost at each 1A reduction. However, extensive tests showed that the quality of image reproduction is maintained up to 2 or 3 reduction levels with size reduction of up to 16 or 64 times before compression by the codec. Such levels of compression are very significant in terms of video storage and transmission costs.
Such tests consisted of using a number of diverse uncompressed video clips, i.e., sports, action movies, educational videos, etc, of about 10 minute duration and requiring tens of Gigabytes of storage space for each. Such video clips were then compressed by a number of different codecs as well as by the methods of the invention. The resulting compressed files were compared for size and then decompressed and played back side by side to compare the perceived quality. Such tests clearly demonstrated that methods of the invention can be suitable for providing additional substantial compression of files, and decompression of the files without significant loss of quality. Photographic examples of some of these tests are provided herein as FIGs. 10-21.
The reproduction by any codec of the reduced size frame is precise enough to be able to apply the above calculations for recovery of the original full size frames with similar quality to that of the frames recovered by the codec without the initial frame size reduction step.
Frame Post-Processing and Frame Expansion
This step of the invention can produce high quality full-screen frames for display on a TV set or PC Monitor. Because of the amount of data involved, standard approaches can be very time-consuming and cannot produce high quality enlargements in any case. The techniques developed to complete the frame expansion methods of the invention can be simple computationally, i.e., fast, and can generate enlarged images of high quality with no pixelization and showing none of the blocking artifacts that plague state-of-the-art techniques. The methods of this invention can be applied repeatedly with similar results and enlargement factors of 4 every time it is applied.
In addition, the process can be further extended by using, after more than 2 or 3 reduction levels, any of the expansion filters disclosed in U.S. Patent No. 7,317,840 to enlarge very small images with high quality. U.S. 7,317,840 is expressly incorporated fully by reference herein.
Overall enlargement factors of more than 1000 have been demonstrated with such an extension.
The image expansion technique disclosed in such a patent is based on the fact that the given image can be considered to be the level 1 low frequency component of the WT of a higher resolution image which is four times larger. One way to accomplish this is to estimate the missing high frequency WT coefficients of level 1 from the given low frequency coefficients.
A discussion of wavelet theory is provided in "Ten Lectures on Wavelets", I. Daubechies, Society for Industrial and Applied Mathematics, Philadelphia, 1992, incorporated herein fully by reference. However, in brief, wavelets are functions generated from a single function ψ by dilations and translation.
Figure imgf000017_0001
Where j corresponds to the level of the transform, and hence governs the dilation, and n governs the translation.
The basic idea of the wavelet transform is to represent an arbitrary function f as a superposition of wavelets.
(2) f= ∑ an j(f)
Since the Ψn J constitute an orthonormal basis, the wavelet transform coefficients are given by the inner product of the arbitrary function and the wavelet basis functions:
Figure imgf000017_0002
In a multiresolution analysis, one really has two functions: a mother wavelet Ψ and a scaling function φ. Like the mother wavelet, the scaling function φ generates a family of dilated and translated versions of itself:
(4) qpn j (X) = 2"j/2 qp (2-j x-n) When compressing data files representative of images, it can be desirable to preserve symmetry. As a result, the requirement of an orthogonal basis may be relaxed (although it is not necessary) and biorthogonal wavelet sets can be used. In this case, the Ψn J no longer constitute an orthonormal basis, hence the computation of the coefficients an J is carried out via the dual basis,
(5) aπ J (f) = < Tπ J, f >
where Ψ is a function associated with the corresponding synthesis filter coefficients defined below.
When f is given in sampled form, one can take these samples as the coefficients xn J for sub-band j = 0. The coefficients for sub-band j+1 are then given by the convolution sums:
(6a) Xn j+I = ∑ h∑n-k Xic* for low frequency coefficients; and k
(6b) Cn J+1 = X g2n-k Xkj for high frequency coefficients, k
This describes a sub-band algorithm with:
Figure imgf000018_0001
representing a low-pass filter and
(7b) gi = (-1)1 h_ι+i, representing a high-pass filter. Consequently, the exact reconstruction is given by: (8) Xr1 = JXh2n-I Xn J+1 + g2n-ι Cn J+1), where h2n.| and g2n-, represent the n reconstruction filters.
The relation between the different filters is given by: (9a) gn = (-l)n h.n+1 or gn = (-l)n+1 Kn+1 (biorthogonal)
(9b) gn = (-1)" En+1 or gn = (-l)n+1 h-n+i (biorthogonal)
(9c) Y, hn hn+2k = δkj0 (delta function) n
where hn and gn represent the low-pass analysis filter and the high-pass analysis filter respectively, and hn and gn represent the corresponding synthesis filters.
We now turn to a matrix modified formulation of the one-dimensional wavelet transform. Using the above impulse responses hn and gn, we can define the circular convolution operators at resolution 2J: HJ, Gr1, HJ, G1. These four matrices are circulant and symmetric. The HJ matrices are built from the hn filter coefficients and similarly for G1
(from gn), HJ (from hn) and G1 (from gn).
The fundamental matrix relation for exactly reconstructing the data at resolution 2" is
(10) HJ HJ + G1 G> = IJ where IJ is the identity matrix.
Let XJ+1 be a vector of low frequency wavelet transform coefficients at scale 2"^+1) and let C/1"1 be the vector of associated high frequency wavelet coefficients. We have, in augmented vector form:
x J+I HJ O χj
(H) j+l O G1 xj
where XJ+1 is the smoothed vector obtained from XJ. The wavelet coefficients C/1"1 contain information lost in the transition between the low frequency bands of scales 2"J and 2"^. The reconstruction equation is
xJ + 1
(12) XJ = J J X H G J+l
Since, from equation (11), XJ+I = HJXJ, we can, in principle, recover X! from XJ+1 merely by inverting HJ. However, this is generally not practical both because of the presence of inaccuracies in XJ+1 and because HJ is generally an ill-conditioned matrix. As a result, the above problem is ill-posed and there is, in general, no unique solution.
If we discard the high frequency coefficients, C/1"1, then equation (12) reduces to y1 = HJXJ+1
which is a blurred approximation of XJ.
From equation (11), XJ+1 - HJXJ, which gives (13a) HJ XJ+1 = HJ HJ XJ or
(14) XJ+1 = HJ XJ.
In our problem, the XJ+1 (transformed rows or columns of level j+l) are known and the problem is to determine the XJ of the next higher level.
This can be thought of as an image restoration problem in which the image defined by the vector XJ has been blurred by the operator HJ, which due to its low-pass nature, is an ill-conditioned matrix.
Regularization, as in "Methodes de resolution des problems mal poses", A.N. Tikhonov and V. Y. Arsenin, Moscow, Edition MIR, incorporated herein fully by reference, is a method used to solve ill-posed problems of this type. This method is similar to a constrained least squares minimization technique.
A solution for this type of problem is found by minimizing the following Lagrangian function:
(15) J (XV) = J XJ+1 - HJ XJ I I2 + o I G> XJ where G is the regularization operator and α is a positive scalar such that α— »0 as the accuracy of XJ+1 increases.
It is also known from regularization theory that if HJ acts as a low-pass filter, G must be a high-pass filter. In other words, since HJ is the low-pass filter matrix of the wavelet transform, G\ must be the corresponding high-pass filter matrix.
Equation (15) may be also written with respect to the estimated wavelet transform coefficients
J+1 and XJ+I (from equation (H)).
(16) J (XJ, α) = I XJ+1 - XJ+1 | 2 + α \ Cj+] | 2 .
Using the exact reconstruction matrix relation shown in Equation 10, we get: (16a) XJ+1 = HJ HJ XJ+1 + C G1 X1+1 .
Also, we can write
(16b) Xϋ+1) = HJ XJ = HJ (H" Xo+1) + G1 Cx 0+0 (keep in mind that XJ is estimated.) Then subtracting (16b) from (16a) gives:
(16c) XJ+1 - ^+1 = G1 G1 X1+1 - HJ G1 Cx 0+0
Substituting (16c) into (16) results in:
(17) J (Cx 0+0, α) = I G1 G XJ+1 - HJ G Cx 0+0 | 2 + α | Cx 1+1 \ 2 . By setting the derivative of J with respect to C/1"1, equal to zero, we can obtain the following estimate for the high frequency coefficients CχJ+ :
Figure imgf000021_0001
where the estimation matrix M is given by
(19) M = I o ϊ + G,J Ht J HJ G1 1 -' Gt J Ht J G1 G
In which the subscript "t" refers to the matrix transpose.
Since the goal is to calculate an estimate of XJ from XJ+1, using equation (12), we can write
(20) XJ = T XJ+1 where T is the matrix
(21) T = H^ G1 M In other words, it is not necessary to calculate the high frequency coefficients Cj+l, although their determination is implicit in the derivation of the matrix T.
One can appreciate that, since we are dealing with a decimated Wavelet Transform, the matrix T is not square, but rather, it is rectangular. Its dimensions are n n/2 where n is the size of the data before any given level of transformation. This can be verified from the following sizes for the Wavelet Transform matrices: H and G are n/2 • n matrices and H and G are n • n/2. Notice that αl + Gt Ht H G is a square matrix of size n/2
• n/2 and is invertible if α>o for all wavelet filters. Another aspect of this invention is the structure of the matrix T. The rows of T are made up of just two short filters that repeat themselves every two rows with a shift to the right of one location. All other elements of the matrix T are zero. This means that every level of the Wavelet Transform can be recreated from the previous level (of half the size) by convolving both filters centered at a specific location of the available data with such data. This results in two new values from every given value thus doubling the size of the data at every level of signal decompression or expansion. There is no need to multiply the matrix T with the given vector. The two filters depend on the coefficients of the wavelet filters used to transform the original data in the case of compression while any wavelet filter coefficients can be used to determine the two expansion filters. The most significant criteria being quality and speed.
For example, for a Daubechies - 6 wavelet, the two filters that make up the matrix T are x, = 0.04981749973687
X2 = -0.19093441556833
X3 = 1.141116915831444 and
y, = -0.1208322083104 y2 = 0.65036500052623 y3 = 0.47046720778416 and the T matrix is: xi X2 X3 O's
T = 0 y yii y yi2 y y33 O's
0 Xi X2 X3 O's
0 0 yi ya ys O's
0 0 Xi X2 X3 O's etc.
Using other wavelet bases, similar expansion filters can be obtained. The following Table 1 provides the wavelets and lengths of filters obtained with a Matlab program of for some typical wavelets.
Table 1
Wavelet Expansion
Daubechies - 4 2
Daubechies - 6 3
Daubechies - 8 4
Biorthogonal 3 - 4
Asymmetrical 2
It can be appreciated that better expansion quality can be obtained using longer filters, whereas naturally shorter filters can provide faster expansion.
It is important to notice that these expansion filters do not depend on the size of the data. By contrast, the undecimated Wavelet Transform results in full matrices with no zeros and whose elements change with the size of the data. Thus, the practical advantages of the method disclosed in this patent are obvious in terms of computational complexity and capability to recreate signals with high quality from low frequency information alone.
With respect to images and video frames, the method is applied first to columns and then to rows. Also, for color images, the method is applied separately to the luminance (Y) and the chrominance (UV) components.
The procedures of the invention can be extended to other wavelets in addition to the Haar Wavelet, although the calculations are more complicated and time consuming. In some embodiments, the corresponding equations for the WT and IWT lead to a sparse system of linear equations in which only a small number of its matrix elements are nonzero, resulting in a band diagonal matrix in which the width of the band depends on the number of Wavelet coefficients. There are software packages applicable to such systems, e.g., Yale Sparse Matrix Package, but the Haar method above provides the quality and speed that make such more complicated approaches unnecessary for situations in which real-time processing is an important requirement.
Take for example the Daubechies-4 Wavelet with low-frequency coefficients: a4 = 0.4829629131445341 / V2 a3 = 0.8365163037378077 / V2 a2 = 0.2241438680420134 / V2 al = -0.1294095225512603 / <2 and high frequency coefficients b4 = al b3 = -a2 b2 = a3 bl = -a4
The coefficients for the inverse wavelet transform are:
- low frequency: aa4 = -0.1294095225512603 * V2 aa3 = 0.2241438680420134 * <2 aa2 = 0.8365163037378077 * <2 aal = 0.4829629131445341 * <2
- high frequency bb4 = -aal bb3 = aa2 bb2 = -aa3 bbl = aa4
Similarly to the case of the Haar Wavelet, we can express the values of the pixels, yi's, of a row or a column of an image or video frame given the values of their low frequency WT, Xj's, and the values of their high frequency WT, Zj's, as yo = aa4Xo + aa2xi + bb4Zo + bb2zi yi = aa3Xi + aaιx2 + bb3Zi + bbiz2 y2 = aa4Xi + aa2x2 + bb4Z| + bbjz2 y3 = aa3x2 + aaιx3 + bb3z2 + bt>iz3 etc.
y2n-2 = a∑MXn-i + aa2xo + bb4zn-i + bb2zo y∑n-i = aa3xo + aaiXi + bb3zo + bbiZi (wraparound) but we have that zo = b4y2n-3 + b3y2n-2 + b2y2n-i + biy0 (wraparound) Zi = b4y2n-i + b3y0 + b2yt + biy2 Z2 = b4yι + b3y2 + b2y3 + biy4 etc.
Zn-2 = b4y2n-6 + b3y2n-5 + b2y2n-4 + b|y2n-3
Zn-I = b4y2n-4 + b3y2n-3 + b2y2n-2 + biy2n-i
Therefore we have a system of equations in hundreds or thousands of variables in which most of the coefficients are zero, i.e., a sparse diagonal linear system. As indicated, there are packages to solve such systems but the Haar Wavelet provides the fastest and most efficient way to reconstruct an image from its low frequency WT. Therefore, using other wavelets is unnecessary and not cost-effective.
These and other embodiments can be used to produce high-quality replay of video images arising from a number of different sources. For example, movies, and live telecasts (e.g., news broadcasts).
EXAMPLES
The following examples are being presented to illustrate specific embodiments of this invention. It can be appreciated that persons of ordinary skill in the art can develop alternative specific embodiments, based upon the disclosures and teachings contained herein. Each of these embodiments is considered to be part of this invention.
Example 1: Frame Reduction and Expansion Techniques As above indicated, the application of the decimated Haar WT to a given video frame results in a frame that is !Λ the original size because only the low-frequency Haar wavelet filter is applied. It has been proven above that the high-frequency Haar wavelet filter need not be applied if just the last original value before wavelet transformation of a row or column pixel is saved. With this information, all the preceding original pixels of a row or column can be calculated exactly.
This process can be repeated again on the resulting reduced frame for additional sized reduction to 1/16 of the original and so on. This process is described in detail below.
Example 2: One-Level Frame Size Reduction and Expansion Back to the Original Size
FIG. 4 depicts drawing 400 showing a one-level frame size reduction to 1A of its original size according to an embodiment of this invention. Frame A 410 has horizontal dimension x and vertical dimension y. Column LC415 and row LR420 are identified, and pixel (X) 425 is shown. First step 426 is horizontal frame reduction, producing Frame B 430, having horizontal dimension x/2 and vertical dimension y. Column (LC) 435 and row (LR/2) 440 are identified, as is pixel X 445. Second step 446 is vertical frame reduction, producing Frame C 450, having horizontal size x/2 and vertical size y/2. Column (LC/2) 455, row (LR/2) 460 and pixel (X) 465 are identified.
In FIG. 4, "A" is the original frame with dimensions x and y. The decimated low- pass Haar WT is applied to A horizontally, resulting in a frame "B" of dimensions (x/2) and y. The last column of A, i.e., ("LC"), is copied to the last column of B, x/2 + 1. Next, the decimated low-pass Haar WT is applied to the (x/2) +1 columns of B resulting in frame "C" of dimensions (x/2) +1 and (y/2). The last row of B, i.e., ("LR/2"), is copied to the last row of C, i.e., y/2 + 1. Notice that pixel X (R, G, B, or Y, U, V component) is kept through this process. LR/2 is the decimated WT of LR and LC/2 is the decimated WT of LC. The process of recovering the original frame from C of FIG. 4 is shown in FIG.
5. First the last row of C is used to precisely recover the columns of B using the frame post-processing reconstruction calculations disclosed above. Finally, the reconstruction method is applied to B horizontally starting with the values of LC reconstructed from the value of X using the reconstruction calculations from right to left to recover A exactly. This procedure can be interfaced to any existing codec (as part of the research of this invention, it has been applied with similar results to the most popular codecs, (i.e., MPEG-4, H.264, VC-I, DivX) to improve its compression performance significantly (60% to 80% reduction in storage and transmission costs for all extensively tested video files) with minimal loss of video quality compared to that produced by the original codec after decompression. First, a frame pre-processing size reduction process of an embodiment of the invention is applied to the original frames of a given video file. Then, a codec is applied to each frame in the given video file. Application of methods of this invention produces a much smaller file than without the frame pre-processing size reduction step. The resulting compressed video file of this invention can then be stored and/or transmitted at a greatly reduced cost.
An implementation of a one level frame pre-processing step of an embodiment of the invention corresponds to the pseudocode below:
- For every row in input frame pFrameln
{ o Compute the decimated low-frequency Haar WT for consecutive pixels o Store in half the width of pFrameln the resulting values o At end of row, store the last pixel unchanged
}
For every 2 consecutive rows in modified pFrameln
{ o Compute the decimated low frequency Haar WT of corresponding pixels in the 2 rows column by column o Store the resulting values in output frame pFrameOut o Advance row position by 2
} Store the last row of the modified pFrameln in pFrameOut last row. This process produces a reduced frame of VA the size of the original frame.
Optionally, an implementation of a second level step includes the additional instruction:
• Repeat with pFrameOut as the input for this step.
Using a second level step reduces the size of the frame to 1/16 of the original size.
Optionally, an implementation of a third level step includes the additional instruction:
• Repeat with pFrameOut of the previous step as the input for this step.
Using a third level step reduces the size of the frame to 1/64 of the original size. In this description, the computation of the decimated low-frequency Haar WT simply involves taking the average of two consecutive pixels, i.e., the average of each of their components (Y, U, V or R, G, B), and making such average the value of the WT in the corresponding position as we move along the rows of the image first and then down the columns of the WT of the rows. This WT of the original image results in a new image that looks very much like the original but at !Λ its size.
An implementation of a one level frame post-processing step of this invention corresponds to the pseudocode below:
- Copy last row of input frame pFrameln into intermediate output frame Img with the same pixels per row as pFrameln and double the number of rows.
- For each pixel position of pFrameln and Img
{ o Calculate the new pixel values of 2 rows of Img starting at the bottom and moving up column by column according to the formulas y2n = (2xn + y2n+i)/3 and y∑n-l = (4Xn - y2n+l)/3 (the x's represent pixels of pFrameln and the y's represent pixels of
Img) o Store the calculated pixels in Img
}
For every row of Img { o Start with the last pixel and store it in the last pixel of the corresponding row of the output frame pFrameOut o Compute the pixels of the rest of the row from right to left according to the above formulas where now the x's represent the pixels of Img and the y's represent the pixels of pFrameOut o Store the calculated pixels in pFrameOut }
This one level post-processing step increases the size of the frame by 4-fold compared to the input frame size.
Optionally, to provide a second level post-processing, an embodiment of this invention includes the following step:
• Repeat with pFrameOut of the previous level being the input in this case. This produces a frame that is 16-fold larger than the original input frame. Optionally, to provide a third level post-processing, an embodiment of this invention further includes the step: • Repeat with pFrameOut of the previous level being the input of this level. This produces a frame that is 64-fold larger than the original input frame.
In this description, the resulting pFrameOut is an almost identical reproduction of the original image before the frame pre-processing step of size reduction because of the formulas of the invention used in the computation of the new pixels.
For decompression and display, the codec is applied for decompression and then the above frame post-processing or size expansion procedure of an embodiment of the invention is used prior to displaying high-quality video in its original full-size.
FIG. 5 depicts a drawing 500 showing a one-level frame size expansion according to an embodiment of this invention. Reduced Frame C 510 has horizontal size x/2+l and vertical size y/2+1. Frame C 510 has Column 515 and Row 520, with pixel (X) 525 shown. Vertical expansion step 526 produces Frame B 530, having a horizontal dimension x/2+l and vertical dimension y. Column (LC) 535 is identified. Horizontal expansion step 536 produces Frame A 540 having horizontal dimension x and vertical dimension y as in the original frame.
Because of the lossy compression of existing standard video codecs, there is some minor loss of video quality compared to the original before compression by the codec but the methods of the invention described here do not result in any perceived degradation of quality when compared to that produced by the codec on its own from a much larger file.
Example 3: Multiple-Level Frame Size Reduction and Expansion
The process of embodiments of the invention described in FIGs. 4 and 5 can be continued by one or more levels starting with the C frame instead of the A frame. There are additional right columns and bottom rows to be saved but they are one half the sizes of the previous level and, consequently, they don't appreciably detract from the saving in storage and transmission bandwidth.
FIG. 6 depicts a drawing 600 of a two-level size reduction according to an embodiment of this invention including another level of frame reduction compared to FIG. 4. In FIG. 6, frame C 610 has horizontal dimension x/2+l and vertical dimension y/2+1. Columns (LC2) 620 and (LCl/2) 615 are identified. Rows (LR2) 630 and (LR1/2) 625 are also identified. Pixels (X) 635 and (Y) 640 are identified. By application of size reduction step 636 in the horizontal dimension, frame D 650 is produced, having horizontal dimension x/4 and vertical dimension y/2. Columns (LC2) 620 and (LC 1/2) 615 are identified, as are rows (LR2/2) 645 and (LR1/4) 650. Pixels (X) 637, (Y) 642 and (Z) 655 are shown. With size reduction step 638 in the vertical direction, frame E 660 is produced, having horizontal dimension x/4 and vertical dimension y/4. Columns (LC2/2) 665 and (LC 1/4) 670, rows (LR2/2) 645 and (LR1/4) 650 are shown. Pixels (X) 675, (Y) 680, (Z) 685 and (W) 690 are also shown.
FIG. 7 depicts drawing 700 of a one-level expansion of a two-level reduction according to an embodiment of this invention. Frame E 710 has horizontal dimension x/4 and vertical dimension y/4. Columns 720 and 725, Rows 730 and 735, and pixels (X) 740, (Y) 745, (Z) 750 and (W) 755 are shown. Application of frame expansion step 756 in the vertical dimension (vertical frame post-processing), produces frame F 760 having horizontal dimension x/4 and vertical dimension y/2. Columns 765 and 770, Row 775, and Pixels (X) 780 and (Z) 785 are shown. With horizontal expansion step 786 (horizontal frame post-processing), frame G 790 is produced having horizontal dimension x/2 and vertical dimension y/2. Column 792, Row 794 and Pixel (X) 796 are shown. FIG. 8 depicts drawing 800 of a three-level size reduction according to an embodiment of this invention. Frame E 810 has horizontal dimension x/4 and vertical dimension y/4. Columns 812 and 814, Rows 816 and 818, and Pixels (X) 820, (Y) 822, (Z) 824 and (W) 826 are shown. With horizontal size reduction step 828, frame H 830 is produced, having horizontal dimension x/8 and vertical dimension^//. Columns 832, 834 and 836, Rows 838 and 840, and Pixels (X) 842, (Y) 844, (Z) 846, (W) 848, (R) 850 and (S) 852 are shown. With additional vertical size reduction step 849, frame I 860 is produced, having horizontal dimension x/8 and vertical dimension y/8. Columns 861, 862 and 863, Rows 864, 865 and 866, and Pixels (T) 867, (R) 868, (S) 869, (U) 870, (Y) 871, (Z) 872, (V) 873, (W) 874 and (X) 875 are shown. FIG. 9 depicts drawing 900 of a one-level frame expansion of a three-level frame reduction according to an embodiment of this invention. Frame I 910 has horizontal dimension x/8 and vertical dimension y/8. Columns 912, 913 and 914, and Rows 915, 916 and 917 are shown. Pixels (X) 918, (W) 919, (V) 926, (U) 922, (Y) 921, (Z) 920, (T) 923, (R) 924 and (S) 925 are shown. Application of frame expansion step 927 in the vertical dimension produces frame J 930. Frame J 930 has horizontal dimension x/8 and vertical dimension >/4. Columns 931, 932 and 933, and Rows 934 and 935, and Pixels (X) 936, (W) 937, (Y) 939, (Z) 938, (R) 940 and (S) 941 are shown. Application of frame expansion step 945 in the horizontal dimension produces frame K 950. Frame 950 has horizontal dimension x/4 and vertical dimension y/4. Columns 951 and 952, Rows 953 and 954, and Pixels (X) 955, (W) 956, (Y) 957 and (Z) 958 are shown.
It can be appreciated that similar approaches can be applied to provide additional levels of reduction and expansion without departing from the scope of this invention.
Modes of Operation
The above ideas and methods can be implemented in a number of different ways.
For example, (1) frame size reduction of only one level but codec compression at different levels of bit assignment per compressed frame; and (2) frame size reduction of multiple levels and codec bit assignment as a function of the reduced frame size of the different levels.
Example 4: Frame Pre-Processing Code
This Example provides one specific way in which the principles of this invention can be implemented to pre-process frames in the horizontal and vertical dimensions to reduce their size prior to compression and decompression using a codec.
Void CAviApi : : RCBFrameReduce( int x. int y. int nFrames. Unsigned char* pFrameln unsigned char * pFrameOut ) {
Unsigned char *pFinO. *pFinl. *pFin2 : int szin.i, j, k01.k02.kl.k2ix: szin=3*(x/2) *y: unsigned char *Fin2=(unsigned char *) malloc(sizeof (unsigned char) *szin): //unsigned char *Fin3(unsigned char *) malloc(sizeof (unsigned char) *szin): pFinO=pFrameIn: pFinl=pFin2:
//pFin2=pFin3: pFrameIn=pFinO+6 : ///////////////////////////////////////HORIZONT 1AL///////////////////////////////////////
I=O: while (i<y) {
J=I : while G<x/2) { Fin2[0] = (pFrameIn[O]»l) + (pFrameIn[3]»l):
Fin2[l] = (pFrameIn[l]»l) + (pFrameIn[4]»l): Fin2[2] = (pFrameIn[2]»l) + (pFrameIn[5]»l): pFrameln += 6: Fin2 +=3: J++: } pFrameIn-=3 : Fin2[0]=pFrameIn[0]: Fin2[l]=pFrameIn[l]: Fin2[2]=pFrameIn[2]: pFrameIn+=9: Fin2+=3: j++: } //CopyMemory(Fin3.Fin2.szin):
Fin2=pFinl : i=l: while (i<y/2) } j=0: while 0<x/2) { pFrameOut[0]=(Fin2[0]»l)+(Fin2[3*x/2]»l): pFrameOut[l]=(Fm2[l]»l)+(Fin2[l+3*x/2]»l): PFrame0ut[2]=(Fin2[2]»l)+(Fin2[2+3*x/2]»l):
// pFrameOut[0]=(*pFinl)»l+(*pFin2)»l :
// pFrameOut[l]=(*pFinl+l))»l+(*(pFin2+l))»l :
// pFrameOut[2]=(*pFinl+2))»l+(*(pFin2+2))»l : pFrameOut+=3: Fin2+=3: //pFinl+=3: //PFin2+=3: j++: }
Fin2+=3*x/2: //pFinl+=3*x/2:
//pFin2+=3*x/2: i++: }
Fin2-=3*x/2:
//pFinl-=3*x/2: memcpy(pFrameOut.Fin2.3*x/2):
//memcpy(pFrameOut.pFin 1.3 *x/2) :
} iiiniiiiiiiiiiiiiiiiiiiiiiiiiiitiiiiniiiiiiiiiiiiiiiiiiiniuiiniiiiiiiiiiiiiiiniiuiiiiiiiiiiiiiiiπiiiiiiiiiiiiiiiiiinii
Example 5: Frame Post-Processing Code
This Example provides one specific way in which the principles of this invention can be implemented to post-process frames in the horizontal and vertical dimensions to expand their size after decompression of a video file using a codec. Void CaviApi : : RGBFrameReduce(int x. int y. in nFrames. unsigned char* pFrameln. unsigned char * pFrameOut)
( unsigned char *pFinO.*pFinl.*pFin2: int szin.i.j.k01.k02.kl.k2.ix: szin=3*(x/2)*y: unsigned char *Fin2=(unsigned char *) malloc(sizeof (unsigned char) *szin): //unsigned char *Fin2=(unsigned char *) malloc(sizeof {unsigned char) *szin): pFinO=pFrameIn. pFinl=pFin2: //pFin2=pFin3: pFrameIn=pFinO+6 :
i=0 while (i<y) {
J=I : while G<x/2) {
Fin2[0] = (pFrameIn[0]»l) + (pFrameIn[3]»l): Fin2[l] = (pFrameIn[l]»l) + (pFrameIn[4]»l):
Fin2[2] = (pFrameIn[2]»l) + (pFrameIn[5]»l): pFrameln += 6: Fin2 +=3: j++: } pFrameIn-=3 : Fin2[0]=pFrameIn[0]: Fin2 [ 1 ] =pFrameIn [I]: Fin2[2]=pFrameIn[2]: pFrameIn+=9: Fin2+=3: i++: }
//CopyMemory(Fin3.Fin2.szin): Fin2=pFinl : i=l : while (i<y/2) { j=0: while 0<x/2) { pFrameOut[0]=(Fin2[0]»l)+(Fin2[3*x/2]»l):
PFrame0ut[l]=(Fin2[l]»l)+(Fin2[l+3*x/2]»l): pFrameOut[2]=(Fin2[2]»l)+(Fin2[2+3*x/2]»l): // pFrameOut[0]=( *pFinl)»l+( *pFin2)»l :
// pFrameOutPH *pFinl+l))»l+(* (pFin2+l))»l):
// pFrameOut[2]=( *pFinl+2))»l+(* (pFin2+2))»l): pFrameOut+=3: Fin2+=3:
//pFinl+=3:
//PFin2+=3: j++: } Fin2+=3*x/2: //pFinl+=3*x/2: //pFin2+=3*x/2: i++: }
Fin2-=3*x/2: //pFinl-=3*x/2:
Memcpy(pFrameOut.Fin2.3 *x/2): //memcpy(pFrameOut.pFinl .3*x/2):
}
Example 6: Comparison of Some Video Codecs Compressed Using Methods of This Invention
Table 2 below presents working examples of video compression improvements of some widely used standard video codecs through application of methods of this invention, without loss of video quality for any given codec. Note that the methods of this invention are applicable to HD 108Oi and 108Op videos, HD 72Op videos, and SD480i videos, as examples, as well as any other formats.
Table 2
Improvement of Video Codec Compression Capabilities Typical Results for MPEG-4, H-264, VC-I
Figure imgf000035_0001
Example 7: Further Levels of Size Reduction and Expansion with Wavelet-based Methods The results described in Examples 4 through 6 can be further improved by additional levels of frame size reduction by using for expansion to the previous level any of the filters obtained from the calculations disclosed in US Patent 7,317,840. For example, using a biorthogonal wavelet, the two resulting filters -0.0575 1.1151 -0.0575 0.0 and -0.0912 0.591 0.591 -0.0912 are convolved consecutively with the rows of a given image or frame to convert every pixel to two pixels of each new expanded row. The process is then repeated vertically column by column to obtain an expanded frame that is four times larger than the original frame. In additional embodiments, other wavelet based expansion filters can be used, for example, the expansion filters of Table 1.
Such wavelet-based filters can be applied to the data of Table 2 to further reduce the video file sizes to about 1/8 and about 1/16 of the size produced by any of the codecs of the Table 2 with little or no perceptible loss in video quality.
Example 8: Results of Application of Methods of This Invention
It can be seen from the preceding Table 1 that the size reductions of video files compressed using the techniques of this invention are about 1A, ιλ, 1A (depending on the level of size reduction) of the compressed files using the codecs alone. The perceived qualities of the decompressed videos for the different reduction levels are indistinguishable from that of the decompressed videos produced by the codec alone for all the codecs. FIGs. 10 through 21 show examples of frame quality produced by a given codec and by the same codec enhanced by pre-processing and post-processing according to methods of this invention. Any differences in quality are clearly imperceptible.
FIGs. 10 through 21 are arranged in sets of three each, wherein the first figure of each set (i.e., FIG. 10, FIG. 13, FIG. 16, and FIG. 19 represent photographs of video frames that have been compressed using only a codec to a compression of 6 Mbps.
The second figure of each set (i.e., FIG. 11, FIG. 14, FIG. 17 and FIG. 20) represent photographs of video frames shown in FIGs. 10, 13, 16 and 19, respectively, that have been pre-processed using methods of this invention, then compressed by the codec, decompressed by the codec and finally post-processed using methods of this invention to provide a compression to 3 Mbps.
The third figure in each set (i.e., FIG. 12, FIG. 15, FIG. 18, and FIG. 21) represent photographs of video frames shown in FIGs. 10, 13, 16 and 19, respectively, that have been pre-processed using methods of this invention, then compressed by the codec, decompressed by the codec and finally post-processed using methods of this invention to provide a compression to 1.5 Mbps.
It can be readily appreciated that the quality of the images of the second and third figure of each of the above sets are of high quality, and show little, if any, perceptible degradation of image quality. Example 9: System for Implementing Pre-Processing, Codecs, and Post- Processing
FIG. 22 depicts a schematic drawing 2200 of a computer-based system for implementing frame pre-processing, codec compression and decompression, and frame post-processing of this invention. An image of Object 2210 is captured as Frame 2214 by Camera 2212. Frame 2214 is transferred at step 2216 to First Device 2220, which contains Buffer 2225 to store Frame 2214, Memory Device 2230 containing instructions for pre-processing and Pre-Processing Module 2235. Frame 2214 is transferred to Pre- Processing Module 2235, and pre-processing steps 2232 of this invention are carried out in Pre-Processing Module 2235, thereby producing a pre-processed frame. The pre- processed frame is transferred to Codec Compression Module 2240, where the pre- processed frame is compressed. The compressed frame is transferred at step 2243 to Receiver 2245, containing Codec Decompression Module 2250, where the compressed frame is decompressed. The decompressed frame is transferred at step 2253 to Device 2260, which contains Memory Device 2270 containing instructions for post-processing. Device 2260 also contains Post-Processing Module 2265, where the decompressed frame is post-processed according to embodiments of this invention. The post-processed frame may be stored in buffer 2275 or transferred directly via step 2277 to Display Monitor 2280, where Post-Processed Image 2290 is displayed.
FIG. 22 also shows that optionally, the compressed frame is transferred at step 2244 to Receiver 2246, containing Storage Device 2251, where the compressed frame is kept for further use. When the frame is needed to be displayed, it is transferred at step 2254 to device 2245 where it is processed as described above. It can be appreciated that similar systems can be constructed in which different codecs are incorporated, each of which receives a pre-processed frame according to methods of this invention, but which are compressed and decompressed using the particular codec. Then, after decompression, post-processing of this invention can be accomplished such that the monitor devices of different systems display images that are similar in quality to each other.
Example 10: Pre-Processing and Post-Processing Devices
This invention includes integrated devices for pre-processing and post-processing of frames according to methods disclosed herein. FIG. 23A depicts a schematic diagram 2300 of Pre-Processing Device 2301 of this invention. Pre-Processing Device 2301 contains a Memory Area 2302 containing instructions for pre-processing, and Processor 2303 for carrying out instructions contained in Memory Area 2302. Such combined memory and pre-processing devices may be integrated circuits that can be manufactured separately and then incorporated into video systems. Connection of Pre-Processing Device 2301 into a video system is indicated at Input 2304, where a frame from an image capture device (e.g., camera) can be input into Pre-Processing Device 2301. Output of the Pre-Processing Device 2301 is shown at Output 2305, which can be connected to a codec (not shown). Optionally, a buffer area (not shown) may be included in Pre- Processing Device 2301.
Similarly, FIG. 23B depicts a schematic diagram 2320 of Post-Processing Device 2321 of this invention. Post-Processing Device 2321 contains a Memory Area 2322 containing instructions for post-processing according to methods of this invention, and also includes Processor 2323 for carrying out instructions contained in Memory Area 2322. Such combined memory and post-processing devices may be integrated circuits that can be manufactured separately and then incorporated into video systems. Connection of Post-Processing Device 2321 to a video system is indicated at Input 2324, where a decompressed frame from a codec (not shown) can be input into Post-Processing Device 2321. Output of the Post-Processing Device 2321 is shown at Output 2325, which can be attached to an output device, such as a video monitor (not shown). Optionally, a buffer area (not shown) may be included in Post-Processing Device 2321.
Example 11: Computer-Readable Devices Containing Instructions for Pre- Processing and Post-Processing
FIG. 24A depicts a schematic drawing 2400 of an embodiment of a computer readable device 2401 of this invention. Device 2401 contains Memory Area 2402, which contains instructions for frame pre-processing according to methods of this invention. Such a device may be a diskette, flash memory, tape drive or other hardware component. Instructions contained on Device 2401 can be transferred at step 2403 to an external preprocessor (not shown) for execution of the instructions contained in Memory Area 2402.
FIG. 24B depicts a schematic drawing 2420 of an embodiment of a computer readable device 2421 of this invention. Device 2421 contains Memory Area 2422, which contains instructions for frame post-processing according to methods of this invention. Such a device may be a diskette, flash memory, tape drive or other hardware component. Instructions contained on Device 2421 can be transferred at step 2423 to an external postprocessor (not shown) for execution of the instructions contained in Memory Area 2422.
References:
The following references are expressly incorporated fully by reference.
1. Ten Lectures on Wavelets by Ingrid Daubechies, Society for Industrial and Applied Mathematics, 1992.
2. US Patent No. 7,317,840 entitled: "Methods for Real-Time Software Video/Audio Compression, Transmission, Decompression, and Display," Angel DeCegama,
Inventor.
INDUSTRIAL APPLICABILITY
Systems and methods of this invention can be used in the telecommunications and video industries to permit high-quality video to be stored, transmitted and replayed at reduced cost and with reduced requirements for computer storage capacity. The implications of aspects of this invention for the reduction of the current staggering costs of video storage and transmission are significant.

Claims

Claims:
1. A system for video image compression and decompression, comprising: a first computer module for image frame pre-processing using direct wavelet transformation (WT); a video codec; a second computer module for image frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT; and an output device.
2. The system of claim 1, wherein said first computer module comprises: an input buffer for storing a video image frame; a memory device storing instructions for frame pre-processing, wherein said instructions are based upon direct wavelet transformation (WT); a processor for implementing said instructions for frame pre-processing, and an output.
3. The system of claim 1 or claim 2, wherein said second computer module comprises: an input buffer; a memory device storing instructions for frame post-processing using WT; a processor for implementing said instructions for frame post-processing; and an output.
4. The system of any of claims 1 to 3, further comprising another storage device for storing a post-processed frame of said video image.
5. The system of any of claims 1 to 4, wherein said instructions for frame pre- processing provide decimated WT and retaining low frequency part of said decimated
WT and discarding high-frequency part of the decimated WT.
6. The system of any of claims 1 to 5, wherein said instructions for frame postprocessing recreate a post-processed frame of original size using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
7. The system of any of claims 1 to 6, wherein said WT is a Haar WT.
8. A computer device for pre-processing a video image frame, comprising: an input; a computer storage module containing instructions for frame pre-processing of a video frame received by said input according to decimated WT; a processor for processing said decimated WT by retaining low-frequency parts and discarding high-frequency parts; and an output.
9. A computer device for post-processing a video image frame, comprising: an input; a computer storage module containing instructions for frame post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT; a processor for processing a video frame received by said input and said instructions to re-create a video image; and an output.
10. The integrated computer device of claim 8 or claim 9, where said WT is a Haar WT.
11. A computer readable medium, comprising: a medium; and instructions thereon to pre-process a video frame using WT.
12. A computer readable medium, comprising: a medium; and instructions thereon to post-process a reduced video frame using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
13. The computer readable medium of claim 1 1 or claim 12, wherein said WT is a Haar WT.
14. A method for producing a video image of an object, comprising the steps: a. providing a digitized image frame of said object; b. providing a decimated WT of said digitized image frame; c. discarding high-frequency components of said decimated WT thereby producing a pre-processed frame; d. compressing said pre-processed frame using a video codec thereby producing a compressed video frame; e. decompressing said compressed video frame using said codec; and f. recreating a full sized image of said frame using post-processing using low-frequency parts of the WT and the last pixel of every row and column of the original image before the WT.
15. The method of claim 14, wherein after step d, transmitting said compressed image to a remote location.
16. The method of claim 14 or claim 15, further comprising displaying said full sized image on a video monitor.
17. The method of any of claims 14 to 16, wherein said step of pre-processing includes a single level frame size reduction according to the following steps:
For every row in input frame pFrameln { o Compute the decimated low-frequency Haar WT for consecutive pixels o Store in half the width of pFrameln the resulting values o At end of row, store the last pixel unchanged
}
For every 2 consecutive rows in modified pFrameln { o Compute the decimated low frequency Haar WT of corresponding pixels in the 2 rows column by column o Store the resulting values in output frame pFrameOut o Advance row position by 2 }
Store the last row of the modified pFrameln in pFrameOut last row.
18. The method of claim 17, further comprising a second level pre-processing.
19. The method of claim 17, further comprising a second level and a third level of pre-processing.
20. The method of any of claims 14 to 19, wherein said step of post-processing includes a first level frame size expansion according to the following steps:
Copy last row of input frame pFrameln into intermediate output frame Img with the same pixels per row as pFrameln and double the number of rows.
For each pixel position of pFrameln and Img
{ o Calculate the new pixel values of 2 rows of Img starting at the bottom and moving up column by column according to the formulas y2n = (2xn + y2n+i)/3 and
V2n-1 = (4xn - y2n+l)/3
(the x's represent pixels of pFrameln and the y's represent pixels of Img) o Store the calculated pixels in Img
}
For every row of Img
{ o Start with the last pixel and store it in the last pixel of the corresponding row of the output frame pFrameOut o Compute the pixels of the rest of the row from right to left according to the above formulas where now the x's represent the pixels of Img and the y's represent the pixels of pFrameOut o Store the calculated pixels in pFrameOut
21. The method of claim 20, further comprising a second level frame size expansion.
22. The method of claim 20, further comprising a second level and a third level of frame size expansion.
23. The method of any of claims 14 to 22, wherein said codec is selected from the group consisting of MPEG-4, H264, VC-I, and DivX.
24. The method of any of claims 14 to 22, wherein further compression is achieved by further pre-processing levels and then expanding such additional levels with expansion filters corresponding to a wavelet selected from the group consisting of Daubechies - 4, Daubechies - 6, Daubechies - 8, biorthorgonal, and asymmetrical wavelets.
25. The method of any of claims 14 to 24, wherein said wavlet is a Daubechies - 6 wavelet, wherein the two filters are:
Filter 1:
Xl = 0.04981749973687
X2 = -0.19093441556833
X3 = 1.141116915831444; and
Filter 2:
Yl = -0.1208322083104
Y2 = 0.65036500052623
Y3 = 0.47046720778416
26. The method of any of claims 14 to 25, wherein the two filters that make up the matrix T, when convolved with an image component selected from Y, U, V, R, G, or B, results in an image component which is 4 times larger than a non-expanded image.
PCT/US2009/004879 2008-08-29 2009-08-26 Systems and methods for compression transmission and decompression of video codecs WO2010024907A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
EP09810374A EP2370934A4 (en) 2008-08-29 2009-08-26 Systems and methods for compression transmission and decompression of video codecs
US12/657,100 US20100172419A1 (en) 2008-08-29 2010-01-12 Systems and methods for compression, transmission and decompression of video codecs
US12/806,153 US8031782B2 (en) 2008-08-29 2010-08-06 Systems and methods for compression, transmission and decompression of video codecs
US13/240,712 US8503543B2 (en) 2008-08-29 2011-09-22 Systems and methods for compression, transmission and decompression of video codecs
US13/958,945 US20130315317A1 (en) 2008-08-29 2013-08-05 Systems and Methods for Compression Transmission and Decompression of Video Codecs

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US19058508P 2008-08-29 2008-08-29
US61/190,585 2008-08-29

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US12/657,100 Continuation US20100172419A1 (en) 2008-08-29 2010-01-12 Systems and methods for compression, transmission and decompression of video codecs

Publications (1)

Publication Number Publication Date
WO2010024907A1 true WO2010024907A1 (en) 2010-03-04

Family

ID=41721804

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2009/004879 WO2010024907A1 (en) 2008-08-29 2009-08-26 Systems and methods for compression transmission and decompression of video codecs

Country Status (3)

Country Link
US (1) US20100172419A1 (en)
EP (1) EP2370934A4 (en)
WO (1) WO2010024907A1 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8031782B2 (en) 2008-08-29 2011-10-04 ADC2 Technologies LLC Systems and methods for compression, transmission and decompression of video codecs
WO2014053982A3 (en) * 2012-10-07 2014-05-30 Numeri Ltd. Video compression method
US10452743B2 (en) 2011-11-07 2019-10-22 Vid Scale, Inc. Video and data processing using even-odd integer transforms

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100091127A1 (en) * 2008-09-30 2010-04-15 University Of Victoria Innovation And Development Corporation Image reconstruction method for a gradient camera
MX371127B (en) * 2014-07-16 2020-01-17 Yamzz Ip Bv Multilevel video compression, decompression, and display for 4k and 8k applications.

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030138152A1 (en) * 2001-12-03 2003-07-24 Simon Fenney Method and apparatus for compressing data and decompressing compressed data
US20040090441A1 (en) * 2002-11-07 2004-05-13 Su Wen-Yu Method and device for translating two-dimensional data of a discrete wavelet transform system
US20040114821A1 (en) * 2002-12-12 2004-06-17 Canon Kabushiki Kaisha Image processing apparatus
US20060176955A1 (en) * 2005-02-07 2006-08-10 Lu Paul Y Method and system for video compression and decompression (codec) in a microprocessor
US20080037880A1 (en) * 2006-08-11 2008-02-14 Lcj Enterprises Llc Scalable, progressive image compression and archiving system over a low bit rate internet protocol network

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5977947A (en) * 1996-08-19 1999-11-02 International Business Machines Corp. Method and apparatus for resizing block ordered video image frames with reduced on-chip cache
US7630569B2 (en) * 2002-02-26 2009-12-08 Decegama Angel Real-time software video/audio transmission and display with content protection against camcorder piracy
US8027547B2 (en) * 2007-08-09 2011-09-27 The United States Of America As Represented By The Secretary Of The Navy Method and computer program product for compressing and decompressing imagery data

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030138152A1 (en) * 2001-12-03 2003-07-24 Simon Fenney Method and apparatus for compressing data and decompressing compressed data
US20040090441A1 (en) * 2002-11-07 2004-05-13 Su Wen-Yu Method and device for translating two-dimensional data of a discrete wavelet transform system
US20040114821A1 (en) * 2002-12-12 2004-06-17 Canon Kabushiki Kaisha Image processing apparatus
US20060176955A1 (en) * 2005-02-07 2006-08-10 Lu Paul Y Method and system for video compression and decompression (codec) in a microprocessor
US20080037880A1 (en) * 2006-08-11 2008-02-14 Lcj Enterprises Llc Scalable, progressive image compression and archiving system over a low bit rate internet protocol network

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP2370934A4 *

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8031782B2 (en) 2008-08-29 2011-10-04 ADC2 Technologies LLC Systems and methods for compression, transmission and decompression of video codecs
US10452743B2 (en) 2011-11-07 2019-10-22 Vid Scale, Inc. Video and data processing using even-odd integer transforms
WO2014053982A3 (en) * 2012-10-07 2014-05-30 Numeri Ltd. Video compression method
CN104704839A (en) * 2012-10-07 2015-06-10 努梅利有限公司 Video compression method
US10334256B2 (en) 2012-10-07 2019-06-25 Numeri Ltd. Video compression method

Also Published As

Publication number Publication date
EP2370934A1 (en) 2011-10-05
EP2370934A4 (en) 2012-10-24
US20100172419A1 (en) 2010-07-08

Similar Documents

Publication Publication Date Title
US8068683B2 (en) Video/audio transmission and display
EP2928190B1 (en) Image data processing
KR100664928B1 (en) Video coding method and apparatus thereof
Jasmi et al. Comparison of image compression techniques using huffman coding, DWT and fractal algorithm
EP0985193B1 (en) Method and apparatus for wavelet based data compression
EP1535239A2 (en) Image processing using probabilistic local behavior assumptions
KR20150068402A (en) Video compression method
JP5133317B2 (en) Video compression method with storage capacity reduction, color rotation, composite signal and boundary filtering and integrated circuit therefor
CA2476904C (en) Methods for real-time software video/audio compression, transmission, decompression and display
EP2370934A1 (en) Systems and methods for compression transmission and decompression of video codecs
WO1999034328A1 (en) Fast dct domain downsampling
KR20000062277A (en) Improved estimator for recovering high frequency components from compressed data
WO2006036796A1 (en) Processing video frames
US20130315317A1 (en) Systems and Methods for Compression Transmission and Decompression of Video Codecs
US8331708B2 (en) Method and apparatus for a multidimensional discrete multiwavelet transform
US7630568B2 (en) System and method for low-resolution signal rendering from a hierarchical transform representation
Deshlahra Analysis of Image Compression Methods Based On Transform and Fractal Coding
Patel Lossless DWT Image Compression using Parallel Processing
Malý et al. Dwt-spiht image codec implementation
KR100854726B1 (en) Apparatus and method for reconstructing image using inverse discrete wavelet transforming
Lakshmi et al. Gaussian Restoration pyramid: Application of image restoration to Laplacian pyramid compression
JP4231386B2 (en) Resolution scalable decoding method and apparatus
Henery Overlapping DCT for image compression
CN111246205A (en) Image compression method based on directional double-quaternion filter bank
Vikal et al. Advanced Image Compression: Haar Wavelet‖

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 09810374

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2009810374

Country of ref document: EP