US8675731B2 - Encoder and method - Google Patents

Encoder and method Download PDF

Info

Publication number
US8675731B2
US8675731B2 US13/584,005 US201213584005A US8675731B2 US 8675731 B2 US8675731 B2 US 8675731B2 US 201213584005 A US201213584005 A US 201213584005A US 8675731 B2 US8675731 B2 US 8675731B2
Authority
US
United States
Prior art keywords
blocks
data
packets
encoder
recited
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
US13/584,005
Other languages
English (en)
Other versions
US20140044190A1 (en
Inventor
Ossi Kalevo
Tuomas KÄRKKÄINEN
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Gurulogic Microsystems Oy
Original Assignee
Gurulogic Microsystems Oy
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 Gurulogic Microsystems Oy filed Critical Gurulogic Microsystems Oy
Assigned to GURULOGIC MICROSYSTEMS OY reassignment GURULOGIC MICROSYSTEMS OY ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KALEVO, OSSI, KARKKAINEN, TUOMAS
Priority to BR102013020622-9A priority Critical patent/BR102013020622B1/pt
Priority to TW102128923A priority patent/TWI505694B/zh
Priority to US14/163,820 priority patent/US9258389B2/en
Publication of US20140044190A1 publication Critical patent/US20140044190A1/en
Application granted granted Critical
Publication of US8675731B2 publication Critical patent/US8675731B2/en
Priority to US15/017,750 priority patent/US10333547B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
    • H04N19/12Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
    • H04N19/122Selection of transform size, e.g. 8x8 or 2x4x8 DCT; Selection of sub-band transforms of varying structure or type
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
    • H04N19/12Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/136Incoming video signal characteristics or properties
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/154Measured or subjectively estimated visual quality after decoding, e.g. measurement of distortion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
    • H04N19/17Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
    • H04N19/172Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a picture, frame or field
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
    • H04N19/18Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being a set of transform coefficients
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/189Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding
    • H04N19/192Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding the adaptation method, adaptation tool or adaptation type being iterative or recursive
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/24Systems for the transmission of television signals using pulse code modulation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T9/00Image coding
    • G06T9/007Transform coding, e.g. discrete cosine transform
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
    • H04N19/119Adaptive subdivision aspects, e.g. subdivision of a picture into rectangular or non-rectangular coding blocks
    • 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

Definitions

  • the present invention relates to encoders for receiving input data and encoding the input data to generate corresponding encoded output data. Moreover, the present invention also concerns methods of encoding input data to generate corresponding encoded output data. Furthermore, the present invention also concerns software products recorded on machine-readable data storage media, wherein the software products are executable upon computing hardware for implementing aforesaid methods.
  • Images and videos are stored and communicated to an increasing extent by contemporary human population, for example multimedia content via Internet and wireless communication networks.
  • the images and videos are stored and communicated between devices, software applications, media systems and data services.
  • images and video are captured scanned, transmitted, shared, watched and printed.
  • images and videos are demanding in respect of data memory capacity and communication system bandwidth utilized.
  • communication system bandwidth is limited, such images and videos take significant time to communicate.
  • image and video encoding methods which also provide a degree of data compression.
  • Image and audio files are becoming larger as image quality is progressively improved, for example by adoption of high definition (HD) standards and high dynamic range (HDR).
  • HD high definition
  • HD high dynamic range
  • 3-dimensional (3-D) images, videos and audio are gaining increasing popularity which demands correspondingly more efficient encoding and decoding methods in encoders and decoders, namely “codecs”, to cope with associated increased quantities of data to be communicated and stored.
  • codecs high dynamic range
  • These transformations employ a process wherein portions of a given image, for example a still image or an image forming a part of a video sequence, are divided into blocks which are then subject to encoding processes.
  • the blocks are, for example, 8 ⁇ 8 image elements, 4 ⁇ 4 image elements or similar.
  • Such relatively smaller blocks are employed because larger sizes of blocks result in inefficient encoding processes, although 16 ⁇ 16 image element blocks are sometimes employed.
  • block sizes are selected based upon how well movement can be compensated in an associated block area or based upon a encoding quality parameter, for example a target quality parameter.
  • higher encoded image quality requires smaller blocks which results in less data compression.
  • Certain types of contemporary encoding can even results in an increase in data size, when error correction features such as parity codes and error correction codes are included.
  • the present invention seeks to provide an encoder for encoding input data representative of at least one image and generating corresponding encoded output data representative of the at least one image, wherein the encoded output data is compressed in relation to the input data without any substantial loss of image quality occurring during encoding.
  • the present invention also seeks to provide a method of encoding input data representative of at least one image and generating corresponding encoded output data representative of the at least one image, wherein the encoded output data is compressed in relation to the input data without any substantial loss of image quality occurring during encoding.
  • a method of encoding input data to generate corresponding encoded output data as defined in appended claim 1 : there is provided a method of encoding input data to generate corresponding encoded output data, characterized in that the method includes steps of:
  • the invention is of advantage in that the method is capable of providing efficient encoding of the input data to provide the corresponding encoded output data whilst potentially providing substantially lossless data compression of the encoded output data relative to the input data to be encoded.
  • the method includes using the at least one transformation to compress content associated with the blocks or packets, so that the encoded output data is smaller in size than the input data to be encoded.
  • the method includes selecting between different types of transformation for ensuring that the one or more quality criteria are satisfied.
  • the method includes arranging for the one or more quality criteria to be dynamically variable during encoding of the blocks or packets depending upon a nature of content included within the blocks or packets.
  • the method is implemented such that the blocks or packets are sub-divided so that at least one of their representative parameters describing their content is flat within their sub-divided blocks or packets.
  • the at least one representative parameter is, for example, colour.
  • the method is implemented such that the blocks or packets correspond to a series of images, wherein sub-division of the input data corresponding to a given image to form the plurality of corresponding blocks is made dependent upon content present in one or more images preceding the given image within the temporal sequence of images.
  • the method includes adding header information to the transformed data in step (e) to generate the encoded output data, wherein the header information includes information indicative of the at least one transformation employed in step (b).
  • step (b) includes fetching supplementary information from a database arrangement for use when executing the at least one transformation, the supplementary information including at least one of: algorithms, rules, one or more transformation parameters. More optionally, the method further includes adding header information to the encoded output data indicative of the database arrangement for enabling subsequent decoding of the encoded output data to access the supplementary information when decoding the encoded output data.
  • the method includes employing for the at least one transformation one of more of: data base reference, DC-value, DCT, pulse code modulation (PCM), DPCM, RLE, LZO, VLC, Huffman-coding, arithmetic coding, transform coding, delta coding, bzip2-specific RLE.
  • Other types of transformation are also feasible to employ for the method.
  • the method includes encoding at least one of video and audio information present in the input data.
  • the method includes encoding multiple channels and/or layers in the encoded output data for providing at least one of: interactive video, commercial advertisements, a plurality of viewpoints during sports event reporting, interactive watermarks, interactive pattern recognition, animated 2D/3D user interface buttons.
  • a software product recorded on machine-readable data storage media, wherein the software product is executable upon computing hardware for executing a method pursuant to the first aspect of the invention.
  • a software application for a mobile wireless communication device wherein the software application includes a software product pursuant to the second aspect of the invention.
  • an encoder operable to encode input data to generate corresponding encoded output data, characterized in that the encoder includes data processing hardware which is operable:
  • the encoder is implemented such that the data processing hardware is implemented using computing hardware operable to execute a software product. More optionally, the data processing hardware includes a plurality of processors which are operable to process data in parallel, and the encoder is operable to direct concurrently block and/or packet data to the plurality of processors for encoding to data to be included in the encoded output data.
  • the encoder is operable to select between different types of transformation for ensuring that the one or more quality criteria are satisfied.
  • the encoder is operable to use the at least one transformation to compress content associated with the blocks or packets, so that the encoded output data is smaller in size than the input data to be encoded.
  • the encoder is operable to arrange for the one or more quality criteria to be dynamically variable during encoding of the blocks or packets depending upon a nature of content included within the blocks or packets.
  • the encoder is operable to sub-divide the blocks or packets so that at least one of their representative parameters describing their content is flat within their sub-divided blocks or packets. More optionally, the encoder is implemented such that the at least one parameter corresponds to a colour of the sub-divided blocks.
  • the encoder is implemented such that the blocks or packets correspond to a series of images, wherein sub-division of the input data corresponding to a given image to form the plurality of corresponding blocks is made dependent upon content present in one or more images preceding the given image within the temporal sequence of images.
  • the encoder is operable to add header information to the transformed data to generate the encoded output data, wherein the header information includes information indicative of the at least one transformation employed by the encoder.
  • the encoder is operable to fetch supplementary information from a database arrangement for use when executing the at least one transformation, the supplementary information including at least one of: algorithms, rules, one or more transformation parameters. More optionally, the encoder is operable to add header information to the encoded output data in a manner indicative of the database arrangement for enabling subsequent decoding of the encoded output data to access the supplementary information when decoding the encoded output data.
  • the encoder is operable to employ for the at least one transformation one of more of: data base reference, DC-value, DCT, pulse code modulation (PCM), DPCM, RLE, LZO, VLC, Huffman-coding, arithmetic coding, transform coding.
  • Other types of transformation are optionally employed by the encoder.
  • the encoder is operable to encode at least one of video and audio information present in the input data to be encoded.
  • FIG. 1 is a schematic illustration of an embodiment of an encoder pursuant to the present invention
  • FIG. 2 is a flow chart of steps of a method of encoding input data representative of at least one image and/or audio to generate corresponding encoded output data, wherein the encoded output data is compressed relative to the input data without substantial loss of image quality occurring during encoding;
  • FIG. 3 is an example partitioning of an image into areas corresponding to blocks for encoding using a method whose steps are illustrated in FIG. 2 ;
  • FIG. 4 is an example image and example initial image split to be use according to embodiments
  • FIG. 5 is an example blocks of the example image of FIG. 4 ;
  • FIG. 6 illustrates blocks of portable device in which encoding could be implemented.
  • an underlined number is employed to represent an item over which the underlined number is positioned or an item to which the underlined number is adjacent.
  • a non-underlined number relates to an item identified by a line linking the non-underlined number to the item.
  • the non-underlined number is used to identify a general item at which the arrow is pointing.
  • the present invention is concerned with encoders and associated methods of encoding input data to generate corresponding encoded output data.
  • the method is concerned with receiving input data representative of one or more images and/or one or more audio signals, and then processing the input data in a manner corresponding to partitioning each image into blocks which can be of variable size, and/or partitioning the one or more audio signals into packets which can be of variable size.
  • the method includes processing the blocks and/or packets to generate compressed encoded output data representative of the one or more images and/or the one or more audio signals.
  • Selection of the blocks is determined by an ease with which areas corresponding to the blocks can be encoded; for example, larger blocks are employed for areas of the one or more images which have a substantially constant associated parameter value, and smaller blocks are employed for areas of the one or more images which are difficult to encode on account of relatively abrupt spatial changes in associated parameter values for the areas.
  • the parameters optionally pertain to one or more of: colour, illumination, sliding parameter value, repetitive pattern.
  • Easy encoding corresponds, for example, to at least one parameter associated with a given area being substantially constant within the given area.
  • the method also employs larger blocks for stationary areas in video sequences of images, or to groups of areas in the video sequences of images that are moving similarly, namely blocks which correspond to fixed objects.
  • the blocks are optionally rectilinear in relation to areas of the one or more images which they represent, for example 64 ⁇ 64 elements, 32 ⁇ 16 elements, 4 ⁇ 20 elements, 10 ⁇ 4 elements, 1 ⁇ 4 elements, 3 ⁇ 1 elements, 8 ⁇ 8 elements, 1 ⁇ 1 element and so forth; optionally, the elements correspond to pixels present in the one or more images, but can be subject to scaling operations during encoding, namely each element corresponding to a corresponding plurality of pixels.
  • other shapes of blocks are optionally employed, for example elliptical blocks, circular blocks and so forth.
  • the method can also be applied to encode one or more audio signals, wherein the one or more audio signals are subdivided into packets of variable temporal length, depending upon a nature of the audio signals corresponding thereto, and the packets are then encoded to generate encoded compressed output data; the packets are synonymous with aforesaid blocks but pertain to audio rather than images information.
  • Encoders pursuant to the present invention are capable of concurrently encoding both audio information and image information.
  • the method includes checking a quality of representation of information provided by the blocks relative to corresponding detail in the one or more images to compute a corresponding quality index; in an event that the computed quality index indicates, when compared against a reference quality threshold, that a selection of block sizes has been employed such that the quality of representation of data provided by the blocks is insufficient, the method iterates back and uses progressively smaller blocks until the quality index indicates that the quality of representation is met as defined by the reference quality threshold.
  • the reference quality threshold is made dynamically variable, depending upon content present in the one or more images; for example, when the one or more images are a part of video sequence where there is rapid chaotic activity, the reference quality threshold can be relaxed during the chaotic activity for enabling an enhanced degree of data compression to be achieved.
  • the chaotic activity can be, for example, random features such as flowing turbulent water, flames, falling snow, billowing smoke, ocean waves and so forth, wherein loss of information is not readily discernible when the encoded data is subsequently decoded in a decoder.
  • Determination of blocks in the aforesaid encoder can be optionally based upon one or more criteria as listed in Table 2.
  • Criterion number Criterion 1 Variance or standard deviation of block data as derived from a corresponding area of an input image 2 Mean or sum of an absolute difference between data represented by a given block and a prediction of its value 3 Variance or standard deviation of an absolute difference between data represented by a given block and a prediction of its value
  • predictions in Table 2 are based upon known rules employed when encoding one or more images.
  • the predictions in Table 2 are based upon provided configuration information, for example as provided from selected database references, from prediction directions, from movements of block coordinates within the one or more images, and so forth.
  • a use of a variance or a standard deviation is an approach employed pursuant to the present invention to provide compression of information by describing a mutual relationship of elements included within a given corresponding block.
  • predictions of block data with associated encoding is itself sufficient when performing encoding pursuant to the present invention, but it is optionally desirable to include code prediction error data within the prediction to improve an accuracy of the prediction.
  • a simple data prediction method is employed, for example a mean value, namely “DC” value, of pixels or elements within a given block to be delivered in the encoded output data.
  • Splitting areas of one or more images provided as input data to an encoder implementing the aforesaid method is optionally implemented according to any manner which provides both compression and also substantially maintains image quality, namely is substantially lossless during encoding.
  • the method applies various strategies to such splitting of areas. For example, if a given block includes considerable information, it is optionally split into a plurality of corresponding smaller blocks that are relatively “flat”, namely substantially constant, in relation to their content such that they individually include relatively little information.
  • encoding quality and encoding noise in the encoded output data are optionally employed to control a manner in which splitting up of input images and audio input signals into blocks and packets respectively occurs.
  • the noise in the encoded output encoded data is based on at least one of:
  • the method analyses the blocks thereby generated to determine whether or not any of the blocks can be combined together, subject to aforesaid quality criteria, in order to obtain a greater degree of data compression in the encoded output data.
  • the encoded output data includes information associated with the blocks which defines locations of their corresponding areas in their original images in the input data to be encoded.
  • data associated with the input images is beneficially down-sampled, for example down-sampled in ratios of 2 ⁇ 1:1, 2 ⁇ 2:1, 1 ⁇ 2:1, 4 ⁇ 1:1, or similarly quantized prior to being subject to aforementioned encoding methods.
  • down-sampling is performed in response to a desired quality of encoding desired in the compressed encoded output data generated from applying methods pursuant to the present invention.
  • larger blocks processed by the methods are less quantized than smaller blocks; in other words, a degree of quantization employed is optionally decreased as block sizes are increased.
  • a scaling factor for down-sampling employed is made dynamically variable, for example in response to a nature of content in a sequence of images, for example video, to be encoded.
  • each block has various parameters which describe its contents. These parameters are conveyed when encoding via various “channels”.
  • colour channels describing blocks of an image can include one or more of: black/white (B/W), Y, U, V, red (R), green (G), blue (B), Cyan (C), Magenta (M), Y and K.
  • the input images for encoding and the blocks can be optionally processed when executing the methods using a variety of potential colour or pixels formats, for example Y, YUV420, YUV422, YUV444, RGB444, G and CMYK contemporary standards and formats.
  • the format is optionally planar, interleaved line planar and so forth.
  • the methods of the invention are beneficially operable to change format of images and/or blocks when performing encoding activities; for example, an original image is in an interleaved RGB format and is encoded using methods pursuant to the invention to generate encoded output data in YUV420 format or vice versa.
  • Bit depth namely dynamic range of a pixel when implementing the aforesaid encoding method, is beneficially in a range of 1-bit to 64-bit resolution.
  • different pixel colours or audio channels can be encoding with mutually different resolutions, provided that encoding quality criteria and compression performance of the encoding methods is satisfied.
  • the encoding methods pursuant to the present invention are optionally implemented using encoding parameters and encoding rules and/or tables which are stored on a database and which are accessed when performing encoding activities.
  • the database is creating during the encoding process and delivered for use when implementing the method via an encoder.
  • motion compensation during encoding us beneficially implemented using delivered databases of information to the encoder.
  • the encoder is operable to encode original pixel information present in the input data and/or encode prediction error information. Using database information when encoding input data to generate corresponding encoded output data enables the encoder to adapt to revisions in encoding standards of parameters, tables and similar utilized for encoding.
  • Coding approaches which can be adopted when implementing the encoding methods pursuant to the present invention optionally include one or more of: data base reference, DC-value, DCT, pulse code modulation (PCM), DPCM, RLE, LZO, VLC, Huffman-coding, arithmetic coding, transform coding, delta coding, bzip2-specific RLE.
  • the coding approaches including any combination of aforementioned examples of coding.
  • a coding approach such as Huffman encoding
  • such coding beneficially uses fixed tables of encoding parameters or delivered tables of coding parameters.
  • the encoder is beneficially implemented using computing hardware having data storage arrangements, wherein optimized tables of encoding parameters can be stored in the data storage arrangements for future use when performing encoding operations.
  • reference addresses for enabling a decoder to access databases for obtaining suitable parameters for decoding the encoded output data from the encoder are included in the encoded output data.
  • the databases are accessible via a communication network, for example via Internet.
  • the databases are supported via cloud computing arrangements.
  • the databases can optionally be DC value, 1D/2D-linear transition, 1D/2D-curved transition, a 1D/2D transformation function or some known image block or audio packet structure.
  • the method of encoding pursuant to the present invention when executed on an encoder is operable to encode input data to generate encoded output data, wherein the encoded output data can be output as a bit stream, alternatively stored in data storage media, for example as a data file.
  • the method of the invention is capable of being utilized in a range of possible applications; beneficially, a header for video, image, image block, audio or audio packets beneficially includes supplementary information, such as version number, size of data for the video, image or packet, quality factor threshold employed when encoding, maximum block or packet size, encoding approaches applied, tables of encoding parameters, and any other information for assisting subsequent decoding processes.
  • information that does not vary between blocks is not included for obtaining an enhanced degree of data compression in the encoded output data, or is included at a higher level in the encoded output data, for example at header or sub-header level.
  • Table 3 provides a hierarchical order of levels which are beneficially employed in the encoded output data generated by the encoder.
  • the method of encoding pursuant to the present invention is operable when executed to select and to deliver information pertaining to one or more levels in the encoded output data, for example dependent upon field of application of the method, for example consumer video products, professional image compression apparatus for survey use, X-ray imaging apparatus, magnetic resonance imaging (MRA) apparatus.
  • Similar considerations pertain to orders of levels in encoded output data when the method pursuant to the present invention is employed to encode audio data; there can be employed headers for audio, groups of packets, packets, sub-packets, groups of waveform segments, and waveform segment.
  • FIG. 1 there is shown an illustration of an encoder pursuant to the present invention.
  • the encoder is denoted by 10 and is operable to receive input data 20 and to encode the input data 20 by employing an encoding method pursuant to the present invention to generate corresponding encoded compressed output data 30 .
  • the output data 30 is beneficially encoded in a substantially lossless manner as aforementioned.
  • the encoder 10 is coupled via a communication network 40 to a database arrangement 50 whereat one or more parameters, tables and/or rules for encoding the input are stored.
  • the encoder 10 receives the input data 20 , optionally derives encoding information from the database arrangement 50 via the communication network 40 , and then proceeds to encode the input data 20 to generate the encoded compressed output data 30 .
  • the input data 20 includes at least one of: audio, one or more images, video.
  • the encoded output data 30 includes headers, encoding information as well as encoded data.
  • the output data 30 can be streamed from the encoder 10 , for example for communication via a communication network arrangement to one or more data storage devices or decoders, or stored directly onto machine-readable data storage media, for example server hard drive disk storage, portable solid-state memory devices and so forth.
  • the encoder 10 is beneficially implemented as hardware, for example via PGLA, via one or more software application executable upon computing hardware, or any mixture of hardware and software, for example a parallel processing engine.
  • the encoder 10 can be employed in multimedia products, computers, mobile telephones (“cell phones”), Internet services, video recorders, video players, communication apparatus and similar.
  • the encoder 10 is optionally employed in conjunction with image capture systems, for example surveillance cameras, hospital X-ray systems, hospital MRI scanners, hospital ultrasound scanners, aerial surveillance systems and similar apparatus which generate large quantities of image data wherein lossless compression is desired so as to preserve fine information in the images whilst rendering the quantities of image data manageable for data storage purposes.
  • the encoder 10 is beneficially useable with known apparatus for image processing, for example in conjunction with an image/video processor as described in a published US patent application no. US2007/280355 herewith incorporated by reference, for example in conjunction with an image generator as described in a published US patent application no. US2010/0322301 herewith incorporated by reference, and for example with a pattern recognizer as described in a published US patent application no. US2011/007971 herewith incorporated by reference.
  • steps of a method of encoding input data 20 are denoted by 100 to 200 .
  • the method includes receiving input data for blocks, image, video and/or audio, for example for receiving the aforesaid input data 20 ; image/block type, image/block format information is derived at the first step for inclusion in the encoded output data 30 .
  • the first step 100 is capable of providing writing header information, for example image size information, into the encoded compressed data.
  • a second step 110 executed after the first step 100 , the method includes creating, if needed, initial blocks or packets.
  • a third step 120 executed after the second step 110 , the method includes performing an analysis of block and/or packet information generated by the second step 110 .
  • the method includes determining whether or not one or more blocks and/or packets identified in the third step 120 need to be split, for example for achieving a defined quality of encoding, namely substantially lossless encoding; in an event that one or more blocks or packets are found to need splitting in the fourth step 130 , the method proceeds to a fifth step 140 in which the one or more identified blocks or packets are split into smaller blocks or packets, thereby creating additional new blocks or new packets; in an event that one or more blocks or packets are not required to be split in the fourth step 130 , the method proceeds to a sixth step 150 . On completing the fifth step 140 , when appropriate, the method proceeds to the sixth step 150 .
  • the method includes determining whether or not a last block or packet has been reached which is to be encoded; in an event that there are blocks or packets remaining to be encoded, the method includes returning back to the third step 120 of performing the analysis of block or packet information; in an event that all the blocks or packets have been encoded, the method includes proceeding to an eighth step 170 .
  • the eighth step 170 of the method includes compressing and encoding data, e.g.
  • pixel values, parameters and split information for example using RLE, Huffman, DCT or similar transformations, and writing header information as aforementioned; for example, if DC values of the blocks are sent, they can be firstly optionally delta-encoded, and thereafter corresponding delta-encoded values encoded as RLE and then these encoded using Huffman encoding.
  • the method includes proceeding to a ninth step 180 which is concerned with checking whether or not a last initial block, packet or frame has been reached; in an event that the last initial block, packet or frame has not been reached, the method includes returning to the third step 120 ; in an event that the last initial block, packet or frame has been reached, the method includes proceeding to a tenth step 190 .
  • the method includes performing one or more analyses whether or not image/blocks are, for example, similar to previous image/blocks or, for example black in colour. Analysis might also need some information that can be got from the previous steps. This step enables image/block for the encoded output data 30 more compressed.
  • the method includes proceeding to an eleventh step 200 , wherein the method includes applying end encoding of block, packet, image or video to finalize the encoded compressed output data 30 .
  • the method includes progressing from the seventh step 160 directly to the eleventh step 200 if applicable, e.g. only one block in the image is needed to be encoded and it is e.g. black or similar than the previous block in the previous image. All the encoded data that can be written to the file or streamed out is beneficially made as early as possible to avoid extra buffering.
  • the method of encoding pursuant to the present invention employs, when appropriate, variable block or packet size for providing an optimal solution between data compression in the encoded output data 30 and substantially lossless compression, namely substantially without discernible loss.
  • large coding blocks 300 are employed for an upper left hand corner of a given image, whereas smaller blocks 310 , 320 , 330 are required along right-hand-side and lower edge areas of the image for more accurately providing encoding of these areas.
  • parameters describing image content of the blocks 300 , 310 , 320 , 330 and the position of the blocks within the image are included in the encoded output data 30 .
  • the distribution of the blocks 300 , 310 , 320 , 330 will vary depending upon spatial distribution of content within images to be encoded.
  • the FIG. 3 shows example of the initial split of blocks in the image that is generated in the second step 110 .
  • This initial split of blocks does not require any information to be sent between encoder and decoder, because it can be based e.g. size of the image.
  • a real split of block is done in the fifth step 140 then that information may be delivered from the encoder to the decoder.
  • a practical example on encoding an image is described later.
  • the method of encoding optionally completes encoding of at least one of images, video and audio, and then thereafter outputs the encoded output data 30 .
  • the encoded output data 30 to be output, for example streamed, concurrently with the method executing encoding steps on at least of images, video and audio.
  • Such operation is beneficial when the method of the present invention is employed to encode source data at a server site in real time for streaming to customers, for example for Internet-delivered multimedia services.
  • the method is potentially thereby capable of functioning with small data storage capacity available, and user interruption of streamed encoded data, for example by the user selecting an alternative, avoids an entire video file being encoded when not required by the user, thereby saving computer processing resources.
  • Such considerations are very important for contemporary multimedia streaming services operating via Internet for example.
  • the encoder 10 is beneficially implemented using computing hardware including a parallel processor architecture including a plurality of processors organized to process data in parallel. For example, on account of initial block splitting to provided the split blocks 300 , 310 , 320 , 330 , the split blocks 300 , 310 , 320 , 330 can be distributed the plurality of processors, for example a first processor encoding the blocks 300 , 310 , 320 and a second processor encoding the blocks 330 .
  • the number of channels employed by the encoder 10 to encode images, video and/or audio can be dynamically variable, for obtaining a greater degree of data compression in the encoded output data 30 .
  • images can include multiple layers that can be presented together.
  • the layers optionally pertain to one or more of: subtitles, logos, multi-view images, depth.
  • the layers optionally convey mutually different volumes of data. All associated layer data are encoded in the encoded output data 30 as separate channels, and an associated description regarding how the channels should be combined and used is also included in one or more headers included in the encoded output data 30 .
  • splitting of blocks illustrated in FIG. 3 is merely an example.
  • a temporal sequence of images for example a video sequence
  • objects depicted in the images with well-defined edges often are found to move about within a given field of view of the images, resulting in the splitting of blocks following movements of the objects.
  • the splitting of blocks typically creates the result that follows the edges in the spatial image.
  • the method of encoding pursuant to the invention is capable, via layer and channel encoding executed in the encoder 10 , capable of supporting interactive video presentations for providing new types of content delivery services, for example interactive commercial advertisements, different viewing perspectives when streaming live sports activities such as Formula 1 and so forth, and movies.
  • the encoder 10 allows for movies with localized subtitle layers, interactive watermarks, interactive pattern recognition, animated 2D/3D user interface (UI) buttons and so forth.
  • Image 400 to be encoded has flat blue area 414 (shown as white in the figure for clarity), green area 412 (shown as black in the figure for clarity) and sliding red area 410 (shown as sliding grey in the figure for clarity).
  • the size of image can be arbitrary for example 12 ⁇ 8 or 24 ⁇ 16 or 120 ⁇ 80 etc pixels.
  • the initial block sizes 402 for the image are selected as 4 ⁇ 4 or 8 ⁇ 8 or 40 ⁇ 40 etc respectively for different image sizes.
  • Block B is analysed next.
  • the block B consists also of only blue therefore it is considered as one area.
  • Block C is analysed next.
  • Block C is not uniform therefore it is split to four sub blocks of C 1 , C 2 , C 3 and C 4 .
  • First sub block C 1 is analysed. It consists sliding red area (with colour value of 15 in lower left corner, values of 20 in top left and bottom right corner and value of 25 in top right corner. Sub block C 1 is considered as one area.
  • Sub block C 2 , C 3 and C 4 are analysed respectively.
  • C 2 , C 3 and C 4 consist flat blue and are each marked as flat blue areas.
  • Block D is analysed next. Block D has only one colour, flat blue, and is considered as one area.
  • Block E is analysed next.
  • Block E is not uniform and it is split to four sub blocks of E 1 , E 2 , E 3 and E 4 .
  • Sub blocks E 1 and E 2 are both uniform with colour of flat blue.
  • Sub block E 3 is not uniform and it is split further to four sub blocks E 31 , E 32 , E 33 and E 34 .
  • Each sub block is analysed.
  • E 31 is found out to consist of uniform colour of blue and is marked as flat blue area.
  • E 32 , E 33 and E 34 are found out to be green (with colour value of 5 as an example) and are designated to be green.
  • Sub block E 4 is analysed and found out to be uniform and designated as colour green.
  • Block F is analysed and found out not to be uniform. The block F is split to four sub blocks F 1 , F 2 , F 3 and F 4 .
  • Sub block F 1 is analysed and found out not to be uniform.
  • the sub block F 1 is split further to sub blocks F 11 , F 12 , F 13 and F 14 .
  • Each sub block is analysed.
  • Sub block F 11 is found out to be uniform with colour blue.
  • Sub blocks F 12 , F 13 and F 14 are found out to be uniform with colour green. Values are associates with blocks respectively.
  • Sub blocks F 2 , F 3 and F 4 are further analysed and found out to be uniform with color green. Values are associated with blocks respectively.
  • first two blocks A and B are flat color, next block C 1 is sliding and all rest are flat colour.
  • Said string can further be for example run length coded.
  • Said string can be for example Huffman coded to reduce size.
  • block group E 31 , E 32 , E 33 and E 34 and block group F 11 , F 12 , F 13 and F 14 have same colour values combination and order (10, 5, 5, 5) it can be considered as one element and designed with own value (referred as Combination Value).
  • Said combination value can be stored in a database (of encoder or decoder) and called with Reference Identification number when needed.
  • Split Bits, Method Bits, Values and Combination Values can be stored in encoder hardware as result of encoding or those can be sent to other hardware for decoding purposes.
  • the encoding can be implemented in portable device 600 of FIG. 6 such as smart phone or digital camera or video camera.
  • Portable device 600 can consist of camera 604 for capturing image, display for showing the image, receiver transmitter (RX/TX) 606 to enable communication using cellular networks or local area networks, other Input/Ouput (I/O) 612 such as Universal Serial Bus (USB) or Ethernet, Central Processing Unit (CPU) 608 for executing encoder related algorithms and instructions and memory 610 for storing image from camera, software for the encoder and encoded image content.
  • the portable device 600 can be configured to store encoded images in local memory 610 or it can be configured to send periodically, upon request, upon user action or in real time or close to real time encoded images via RX/TX 606 or via I/O 612 to external systems.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Discrete Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)
  • Error Detection And Correction (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
US13/584,005 2012-08-13 2012-08-13 Encoder and method Active US8675731B2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
BR102013020622-9A BR102013020622B1 (pt) 2012-08-13 2013-08-13 Codificador e método
TW102128923A TWI505694B (zh) 2012-08-13 2013-08-13 編碼器及編碼方法
US14/163,820 US9258389B2 (en) 2012-08-13 2014-01-24 Encoder and method
US15/017,750 US10333547B2 (en) 2012-08-13 2016-02-08 Encoder and method for encoding input data using a plurality of different transformations or combinations of transformations

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
GB1214414.3 2012-08-13
GB1214414.3A GB2503295B (en) 2012-08-13 2012-08-13 Encoder and method

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US14/163,820 Continuation-In-Part US9258389B2 (en) 2012-08-13 2014-01-24 Encoder and method

Publications (2)

Publication Number Publication Date
US20140044190A1 US20140044190A1 (en) 2014-02-13
US8675731B2 true US8675731B2 (en) 2014-03-18

Family

ID=46981439

Family Applications (1)

Application Number Title Priority Date Filing Date
US13/584,005 Active US8675731B2 (en) 2012-08-13 2012-08-13 Encoder and method

Country Status (10)

Country Link
US (1) US8675731B2 (ja)
EP (2) EP2698997A1 (ja)
JP (2) JP6245888B2 (ja)
KR (1) KR101687863B1 (ja)
CN (1) CN103596008B (ja)
BR (1) BR102013020622B1 (ja)
GB (1) GB2503295B (ja)
IN (1) IN2013MU02340A (ja)
RU (1) RU2553103C2 (ja)
TW (1) TWI505694B (ja)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130159263A1 (en) * 2011-12-18 2013-06-20 Numerica Corporation Lossy compression of data points using point-wise error constraints
US20180048333A1 (en) * 2016-08-11 2018-02-15 Zebware Ab Device and associated methodoloy for encoding and decoding of data for an erasure code
US10116328B2 (en) 2015-06-10 2018-10-30 Gurulogic Microsystems Oy Encoders, decoders and methods utilizing mode symbols
US11202083B2 (en) 2015-06-18 2021-12-14 Gurulogic Microsystems Oy Encoder, decoder and method employing palette utilization and compression

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9503744B2 (en) * 2013-01-22 2016-11-22 Vixs Systems, Inc. Video processor with random access to compressed frame buffer and methods for use therewith
GB2523347B (en) * 2014-02-20 2016-01-13 Gurulogic Microsystems Oy Encoder, decoder and method
US10404988B2 (en) * 2014-03-16 2019-09-03 Vid Scale, Inc. Method and apparatus for the signaling of lossless video coding
US20150379682A1 (en) * 2014-06-27 2015-12-31 Samsung Electronics Co., Ltd. Vertex attribute data compression with random access using hardware
GB2528460B (en) 2014-07-21 2018-05-30 Gurulogic Microsystems Oy Encoder, decoder and method
US10284877B2 (en) 2015-01-16 2019-05-07 Hewlett Packard Enterprise Development Lp Video encoder
GB2543844B (en) 2015-11-01 2018-01-03 Gurulogic Microsystems Oy Encoders, decoders and methods
RU2616178C1 (ru) * 2016-03-28 2017-04-12 Федеральное государственное бюджетное образовательное учреждение высшего образования "Тульский государственный университет" (ТулГУ) Способ кодирования-декодирования цифровых статических видеоизображений
US10972125B2 (en) * 2016-06-20 2021-04-06 Anacode Labs, Inc. Storage access interface to an encoded storage system
GB2552223B (en) 2016-07-15 2020-01-01 Gurulogic Microsystems Oy Encoders, decoders and methods employing quantization
CN106534846B (zh) * 2016-11-18 2019-01-29 天津大学 一种屏幕内容与自然内容划分及快速编码方法
KR102142946B1 (ko) * 2019-11-08 2020-08-10 세종대학교산학협력단 다중 dpcm 기법을 이용한 무손실 이미지 데이터 압축 장치 및 방법
CN113055017A (zh) 2019-12-28 2021-06-29 华为技术有限公司 数据压缩方法及计算设备

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2274754A (en) 1993-01-30 1994-08-03 Samsung Electronics Co Ltd Compressing image data in accordance with block contrast
US5832130A (en) 1995-08-28 1998-11-03 Samsung Electronics Co., Ltd. Image signal coding device and method therefor
US6529634B1 (en) 1999-11-08 2003-03-04 Qualcomm, Inc. Contrast sensitive variance based adaptive block size DCT image compression
US20060204115A1 (en) * 2003-03-03 2006-09-14 Dzevdet Burazerovic Video encoding
US7379496B2 (en) 2002-09-04 2008-05-27 Microsoft Corporation Multi-resolution video coding and decoding
US7676101B2 (en) 2002-12-02 2010-03-09 Sony Corporation Method and apparatus for compensating for motion prediction
WO2010087807A1 (en) 2009-01-27 2010-08-05 Thomson Licensing Methods and apparatus for transform selection in video encoding and decoding
US7995849B2 (en) * 2003-03-17 2011-08-09 Qualcomm, Incorporated Method and apparatus for improving video quality of low bit-rate video
US8018994B2 (en) * 2004-06-27 2011-09-13 Apple Inc. Selecting encoding types and predictive modes for encoding video data
US20120027083A1 (en) * 2009-04-03 2012-02-02 Matthias Narroschke Video coding method, video decoding method, video coding apparatus, and video decoding apparatus
US8270738B2 (en) * 2001-07-02 2012-09-18 Qualcomm Incorporated Apparatus and method for encoding digital image data in a lossless manner

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6633611B2 (en) * 1997-04-24 2003-10-14 Mitsubishi Denki Kabushiki Kaisha Method and apparatus for region-based moving image encoding and decoding
CN1278385A (zh) * 1997-10-28 2000-12-27 西门子公司 数字化图象的处理方法和装置
JP3887178B2 (ja) * 2001-04-09 2007-02-28 株式会社エヌ・ティ・ティ・ドコモ 信号符号化方法及び装置並びに復号方法及び装置
CN101448162B (zh) * 2001-12-17 2013-01-02 微软公司 处理视频图像的方法
JP4447197B2 (ja) * 2002-01-07 2010-04-07 三菱電機株式会社 動画像符号化装置および動画像復号装置
US6795584B2 (en) * 2002-10-03 2004-09-21 Nokia Corporation Context-based adaptive variable length coding for adaptive block transforms
HUP0301368A3 (en) * 2003-05-20 2005-09-28 Amt Advanced Multimedia Techno Method and equipment for compressing motion picture data
GB2415335B (en) * 2004-06-15 2007-09-26 Toshiba Res Europ Ltd Wireless terminal dynamically programmable proxies
CN101540912B (zh) * 2004-06-27 2011-05-18 苹果公司 对编码视频数据选择编码类型和预测模式
JP2006157481A (ja) * 2004-11-30 2006-06-15 Canon Inc 画像符号化装置及びその方法
KR101455578B1 (ko) * 2005-09-26 2014-10-29 미쓰비시덴키 가부시키가이샤 동화상 부호화 장치 및 동화상 복호 장치
JP2007243427A (ja) * 2006-03-07 2007-09-20 Nippon Hoso Kyokai <Nhk> 符号化装置及び復号化装置
US20070233477A1 (en) * 2006-03-30 2007-10-04 Infima Ltd. Lossless Data Compression Using Adaptive Context Modeling
KR101373934B1 (ko) * 2006-07-10 2014-03-12 톰슨 라이센싱 멀티 패스 비디오 인코더에서 성능 향상을 위한 방법 및 장치
JP2009194474A (ja) * 2008-02-12 2009-08-27 Toshiba Corp 動画像符号化装置
US8451896B2 (en) * 2009-10-19 2013-05-28 Hong Kong Applied Science and Technology Research Institute Company Limited Method and apparatus for adaptive quantization in digital video coding
CN102495878B (zh) * 2011-12-05 2013-04-10 深圳市中钞科信金融科技有限公司 一种机器视觉检测结果的存储文件及方法

Patent Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2274754A (en) 1993-01-30 1994-08-03 Samsung Electronics Co Ltd Compressing image data in accordance with block contrast
US5832130A (en) 1995-08-28 1998-11-03 Samsung Electronics Co., Ltd. Image signal coding device and method therefor
US6529634B1 (en) 1999-11-08 2003-03-04 Qualcomm, Inc. Contrast sensitive variance based adaptive block size DCT image compression
US8270738B2 (en) * 2001-07-02 2012-09-18 Qualcomm Incorporated Apparatus and method for encoding digital image data in a lossless manner
US7379496B2 (en) 2002-09-04 2008-05-27 Microsoft Corporation Multi-resolution video coding and decoding
US7676101B2 (en) 2002-12-02 2010-03-09 Sony Corporation Method and apparatus for compensating for motion prediction
US20060204115A1 (en) * 2003-03-03 2006-09-14 Dzevdet Burazerovic Video encoding
US7995849B2 (en) * 2003-03-17 2011-08-09 Qualcomm, Incorporated Method and apparatus for improving video quality of low bit-rate video
US8018994B2 (en) * 2004-06-27 2011-09-13 Apple Inc. Selecting encoding types and predictive modes for encoding video data
WO2010087807A1 (en) 2009-01-27 2010-08-05 Thomson Licensing Methods and apparatus for transform selection in video encoding and decoding
US20120027083A1 (en) * 2009-04-03 2012-02-02 Matthias Narroschke Video coding method, video decoding method, video coding apparatus, and video decoding apparatus

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
Bumshik Lee et al., "A Hierarchical variable-sized block transform coding scheme for coding efficiency improvement on H.264/AVC", 2010 Picture Coding Symposium (PCS 2010); Nagoya, Japan, Dec. 8-10, IEEE, Piscataway, NJ, pp. 522-525.
European Search and Examination Repor mailed Nov. 20, 2013 issued in related European application No. 13002521.6-1908 (8 pages).
Search Report under Section 17 dated Oct. 26, 2012 issued by the U.K. Patent Office in related U.K. Application No. GB 1214414.3 (4 pages).

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130159263A1 (en) * 2011-12-18 2013-06-20 Numerica Corporation Lossy compression of data points using point-wise error constraints
US8811758B2 (en) * 2011-12-18 2014-08-19 Numerica Corporation Lossy compression of data points using point-wise error constraints
US10116328B2 (en) 2015-06-10 2018-10-30 Gurulogic Microsystems Oy Encoders, decoders and methods utilizing mode symbols
US11202083B2 (en) 2015-06-18 2021-12-14 Gurulogic Microsystems Oy Encoder, decoder and method employing palette utilization and compression
US20180048333A1 (en) * 2016-08-11 2018-02-15 Zebware Ab Device and associated methodoloy for encoding and decoding of data for an erasure code
US10523244B2 (en) * 2016-08-11 2019-12-31 Zebware Ab Device and associated methodoloy for encoding and decoding of data for an erasure code

Also Published As

Publication number Publication date
EP3082337A1 (en) 2016-10-19
RU2553103C2 (ru) 2015-06-10
JP2014039256A (ja) 2014-02-27
CN103596008A (zh) 2014-02-19
JP2016220216A (ja) 2016-12-22
JP6245888B2 (ja) 2017-12-13
GB2503295A (en) 2013-12-25
TWI505694B (zh) 2015-10-21
BR102013020622B1 (pt) 2022-12-06
IN2013MU02340A (ja) 2015-07-10
TW201412130A (zh) 2014-03-16
EP2698997A1 (en) 2014-02-19
RU2013137368A (ru) 2015-02-20
CN103596008B (zh) 2018-04-13
KR20150129096A (ko) 2015-11-19
KR101687863B1 (ko) 2016-12-28
GB2503295B (en) 2014-08-06
US20140044190A1 (en) 2014-02-13
BR102013020622A2 (pt) 2018-02-27
GB201214414D0 (en) 2012-09-26

Similar Documents

Publication Publication Date Title
US8675731B2 (en) Encoder and method
US9258389B2 (en) Encoder and method
US9538239B2 (en) Decoder and method for decoding encoded input data containing a plurality of blocks or packets
US10333547B2 (en) Encoder and method for encoding input data using a plurality of different transformations or combinations of transformations
WO2017071480A1 (zh) 参考帧编解码的方法与装置
US10412414B2 (en) Decoder and method for decoding encoded input data containing a plurality of blocks or packets
US11412236B2 (en) Method for decoding image on basis of CCLM prediction in image coding system, and device therefor
US20220159247A1 (en) Method and apparatus for constructing prediction candidate on basis of hmvp
US11838519B2 (en) Image encoding/decoding method and apparatus for signaling image feature information, and method for transmitting bitstream
AU2020240943A1 (en) Method and device for signaling information on chroma format
CN112567739B (zh) 用于视觉媒体编码和解码的平面预测模式
US11683480B2 (en) Method and device for decoding images using CCLM prediction in image coding system
KR20230023708A (ko) 영상/비디오 코딩 시스템에서 상위 레벨 신택스를 처리하는 방법 및 장치
CN114762339A (zh) 基于变换跳过和调色板编码相关高级语法元素的图像或视频编码
US11284083B2 (en) Method and apparatus for coding information about merge data
EP2698996A2 (en) Decoder and method
US20220053196A1 (en) Method and apparatus for deriving motion vector
KR20230023709A (ko) 영상/비디오 코딩 시스템에서 일반 제한 정보를 처리하는 방법 및 장치
CN114762335A (zh) 基于变换跳过和调色板编码相关数据的图像或视频编码

Legal Events

Date Code Title Description
AS Assignment

Owner name: GURULOGIC MICROSYSTEMS OY, FINLAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KALEVO, OSSI;KARKKAINEN, TUOMAS;REEL/FRAME:028951/0516

Effective date: 20120827

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551)

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2552); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY

Year of fee payment: 8