pkgsrc/graphics/jpeg_ls/patches/patch-ae

32 lines
993 B
Text
Raw Normal View History

Initial import of jpeg_ls-2.2: This software package contains an implementation of JPEG-LS, the emerging lossless/near-lossless compression standard for continuous-tone images being developed by ISO/IEC JTC1/SC29/WG1 (draft document FCD14495 as of November 1997). The names of the executables in the software package derive from the acronym LOCO, as the core of the new standard is based on the LOCO-I algorithm (LOw COmplexity LOssless COmpression for Images) developed at Hewlett-Packard Laboratories (reference: M. Weinberger, G. Seroussi, G. Sapiro, "LOCO-I: A Low Complexity, Context-Based, Lossless Image Compression Algorithm," Proc. IEEE Data Compression Conference, Snowbird, Utah, March-April 1996). The term "near-lossless compression" refers to a lossy algorithm for which each decompressed image sample differs from the corresponding original image sample by not more than a pre-specified value, the (usually small) "loss." Lossless compression corresponds to loss=0. Even though the term "continuous-tone image" refers in principle to any image whose components have more than one bit per sample, palletized images may require a reordering of the color palette for best compression results using LOCO-I on the array of color indices. This functionality is not implemented in the present software, although it is supported by the new standard, and is easy enough to implement with the tools given. Notice, however, that LOCO-I and JPEG-LS were not designed, and might not give optimal performance, for images that have been palletized through dithering.
2003-12-21 22:29:08 +01:00
$NetBSD: patch-ae,v 1.1.1.1 2003/12/21 21:29:09 wiz Exp $
--- Encoder/initialize.c.orig Tue Jun 22 20:15:24 1999
+++ Encoder/initialize.c
@@ -64,7 +64,7 @@ int vLUT[3][2 * LUTMAX16];
int classmap[CONTEXTS1];
-int *qdiv0, *qdiv, /* quantization table (division via look-up) */
+int *qdiv0, *qdiv1, /* quantization table (division via look-up) */
*qmul0, *qmul; /* dequantization table */
int N[TOT_CONTEXTS],
@@ -229,7 +229,7 @@ void prepare_qtables(int absize, int NEA
perror("qdiv table");
exit(10);
}
- qdiv = qdiv0+absize-1;
+ qdiv1 = qdiv0+absize-1;
if ( (qmul0 = (int *)calloc(2*beta-1,sizeof(int)))==NULL ) {
perror("qmul table");
@@ -242,7 +242,7 @@ void prepare_qtables(int absize, int NEA
qdiff = - ( (NEAR-dif)/quant );
else
qdiff = ( NEAR + dif )/quant;
- qdiv[dif] = qdiff;
+ qdiv1[dif] = qdiff;
}
for ( qdiff = -(beta-1); qdiff<beta; qdiff++ ) {
dif = quant*qdiff;