blob: 9223de2176c12e752d45ee20972d9c4dff3baca1 [file] [log] [blame]
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +00001The Independent JPEG Group's JPEG software
2==========================================
3
Thomas G. Lane88aeed41992-12-10 00:00:00 +00004README for release 4 of 10-Dec-92
5=================================
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +00006
Thomas G. Lane88aeed41992-12-10 00:00:00 +00007This distribution contains the fourth public release of the Independent JPEG
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +00008Group's free JPEG software. You are welcome to redistribute this software and
9to use it for any purpose, subject to the conditions under LEGAL ISSUES, below.
10
Thomas G. Lane88aeed41992-12-10 00:00:00 +000011For installation instructions, see file SETUP.
12
13For usage instructions, see file USAGE (or the cjpeg.1 and djpeg.1 manual
14pages; but USAGE contains a "hints" section not found in the manual pages).
15Useful information can also be found in the JPEG FAQ (Frequently Asked
16Questions) article; see ARCHIVE LOCATIONS below to obtain the FAQ article.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000017
Thomas G. Lanebd543f01991-12-13 00:00:00 +000018This software is still undergoing revision. Updated versions may be obtained
Thomas G. Lane4a6b7301992-03-17 00:00:00 +000019by FTP or UUCP to UUNET and other archive sites; see ARCHIVE LOCATIONS below
20for details.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000021
Thomas G. Lane88aeed41992-12-10 00:00:00 +000022Serious users of this software (particularly those incorporating it into
23larger programs) should contact jpeg-info@uunet.uu.net to be added to our
24electronic mailing list. Mailing list members are notified of updates and
25have a chance to participate in technical discussions, etc.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000026
Thomas G. Lanebd543f01991-12-13 00:00:00 +000027This software is the work of Tom Lane, Philip Gladstone, Luis Ortiz,
Thomas G. Lane4a6b7301992-03-17 00:00:00 +000028Lee Crocker, Ge' Weijers, and other members of the Independent JPEG Group.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000029
30
31DISCLAIMER
32==========
33
34THIS SOFTWARE IS NOT COMPLETE NOR FULLY DEBUGGED. It is not guaranteed to be
35useful for anything, nor to be compatible with subsequent releases, nor to be
36an accurate implementation of the JPEG standard. (See LEGAL ISSUES for even
37more disclaimers.)
38
Thomas G. Lane88aeed41992-12-10 00:00:00 +000039Despite that, we believe that this software is pretty good, and if you find
40any problems with it, we'd like to know about them. Please report problems
41by e-mail to jpeg-info@uunet.uu.net.
Thomas G. Lanebd543f01991-12-13 00:00:00 +000042
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000043
44WHAT'S HERE
45===========
46
Thomas G. Lane4a6b7301992-03-17 00:00:00 +000047This distribution contains C software to implement JPEG image compression and
Thomas G. Lanebd543f01991-12-13 00:00:00 +000048decompression. JPEG (pronounced "jay-peg") is a standardized compression
Thomas G. Lane88aeed41992-12-10 00:00:00 +000049method for full-color and gray-scale images. JPEG is intended for compressing
Thomas G. Lanebd543f01991-12-13 00:00:00 +000050"real-world" scenes; cartoons and other non-realistic images are not its
51strong suit. JPEG is lossy, meaning that the output image is not necessarily
Thomas G. Lane88aeed41992-12-10 00:00:00 +000052identical to the input image. Hence you must not use JPEG if you have to have
53identical output bits. However, on typical images of real-world scenes, very
54good compression levels can be obtained with no visible change, and amazingly
55high compression levels are possible if you can tolerate a low-quality image.
56For more details, see the references, or just experiment with various
57compression settings.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000058
59The software implements JPEG baseline and extended-sequential compression
60processes. Provision is made for supporting all variants of these processes,
61although some uncommon parameter settings aren't implemented yet. For legal
62reasons, we are not distributing code for the arithmetic-coding process; see
63LEGAL ISSUES. At present we have made no provision for supporting the
Thomas G. Lane4a6b7301992-03-17 00:00:00 +000064progressive, hierarchical, or lossless processes defined in the standard.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000065
Thomas G. Lane88aeed41992-12-10 00:00:00 +000066In order to support file conversion and viewing software, we have included
67considerable functionality beyond the bare JPEG coding/decoding capability;
68for example, the color quantization modules are not strictly part of JPEG
69decoding, but they are essential for output to colormapped file formats or
70colormapped displays. These extra functions can be compiled out if not
71required for a particular application.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000072
73The emphasis in designing this software has been on achieving portability and
Thomas G. Lane88aeed41992-12-10 00:00:00 +000074flexibility, while also making it fast enough to be useful. In particular,
75the software is not intended to be read as a tutorial on JPEG. (See the
76REFERENCES section for introductory material.) While we hope that the entire
77package will someday be industrial-strength code, much remains to be done in
78performance tuning and in improving the capabilities of individual modules.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000079
80
81This software can be used on several levels:
82
83* As canned software for JPEG compression and decompression. Just edit the
Thomas G. Lanebd543f01991-12-13 00:00:00 +000084 Makefile and configuration files as needed (see file SETUP), compile and go.
Thomas G. Lane4a6b7301992-03-17 00:00:00 +000085 Members of the Independent JPEG Group will improve the out-of-the-box
Thomas G. Lanebd543f01991-12-13 00:00:00 +000086 functionality and speed as time goes on.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000087
88* As the basis for other JPEG programs. For example, you could incorporate
89 the decompressor into a general image viewing package by replacing the
90 output module with write-to-screen functions. For an implementation on
91 specific hardware, you might want to replace some of the inner loops with
92 assembly code. For a non-command-line-driven system, you might want a
93 different user interface. (Members of the group will be producing Macintosh
Thomas G. Lanebd543f01991-12-13 00:00:00 +000094 and Amiga versions with more appropriate user interfaces, for example.)
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +000095
96* As a toolkit for experimentation with JPEG and JPEG-like algorithms. Most
97 of the individual decisions you might want to mess with are packaged up into
98 separate modules. For example, the details of color-space conversion and
99 subsampling techniques are each localized in one compressor and one
100 decompressor module. You'd probably also want to extend the user interface
101 to give you more detailed control over the JPEG compression parameters.
102
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000103In particular, we welcome the use of this software as a component of commercial
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000104products; no royalty is required.
105
106
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000107ARCHIVE LOCATIONS
108=================
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000109
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000110The "official" archive site for this software is ftp.uu.net (Internet
111address 137.39.1.9 or 192.48.96.9). The most recent released version can
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000112always be found there in directory graphics/jpeg. This particular version
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000113will be archived as jpegsrc.v4.tar.Z. If you are on the Internet, you can
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000114retrieve files from UUNET by anonymous FTP. If you don't have FTP access,
115UUNET's archives are also available via UUCP; contact postmaster@uunet.uu.net
116for information on retrieving files that way.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000117
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000118Numerous Internet sites maintain copies of the UUNET files; in particular,
119you can probably find a copy at any site that archives comp.sources.misc
120submissions. However, only ftp.uu.net is guaranteed to have the latest
121official version.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000122
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000123You can also obtain this software from CompuServe, in the GRAPHSUPPORT forum
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000124(GO PICS), library 15; this version will be file jpsrc4.zip. Again,
125CompuServe is not guaranteed to have the very latest version.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000126
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000127The JPEG FAQ (Frequently Asked Questions) article is a useful source of
128general information about JPEG. It is updated constantly and therefore
129is not included in this distribution. The FAQ is posted every two weeks
130to Usenet newsgroups comp.graphics, news.answers, and other groups. You
131can always obtain the latest version from the news.answers archive at
132rtfm.mit.edu (18.172.1.27). By FTP, fetch /pub/usenet/news.answers/jpeg-faq.
133If you don't have FTP, send e-mail to mail-server@rtfm.mit.edu with body
134"send usenet/news.answers/jpeg-faq".
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000135
136
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000137SUPPORTING SOFTWARE
138===================
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000139
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000140You will probably want Jef Poskanzer's PBMPLUS image software, which provides
141many useful operations on PPM-format image files. In particular, it can
142convert PPM images to and from a wide range of other formats. You can FTP
143this free software from export.lcs.mit.edu (contrib/pbmplus*.tar.Z) or
144ftp.ee.lbl.gov (pbmplus*.tar.Z). Unfortunately PBMPLUS is not nearly as
145portable as the JPEG software is; you are likely to have difficulty making it
146work on any non-Unix machine.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000147
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000148If you are using X Windows you might want to use the xv or xloadimage viewers
149to save yourself the trouble of converting PPM to some other format. Both of
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000150these can be found in the contrib directory at export.lcs.mit.edu. Actually,
151xv version 2.00 and up incorporates our software and thus can read and write
152JPEG files directly. (NOTE: since xv internally reduces all images to 8
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000153bits/pixel, a JPEG file written by xv will not be very high quality; and xv
154cannot fully exploit a 24-bit display. These problems are expected to go away
155in the next xv release, planned for early 1993. In the meantime, use
156xloadimage for 24-bit displays.)
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000157
158For DOS machines, Lee Crocker's free Piclab program is a useful companion to
159the JPEG software. The latest version, currently 1.91, is available by FTP
160from SIMTEL20 and its various mirror sites, file <msdos.graphics>piclb191.zip.
161CompuServe also has it, in the same library as the JPEG software.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000162
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000163
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000164SOFTWARE THAT'S NO HELP AT ALL
165==============================
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000166
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000167Handmade Software's shareware PC program GIF2JPG produces files that are
168totally incompatible with our programs. They use a proprietary format that is
169an amalgam of GIF and JPEG representations. However, you can force GIF2JPG
170to produce compatible files with its -j switch, and their decompression
171program JPG2GIF can read our files (at least ones produced with our default
172option settings).
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000173
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000174Some commercial JPEG implementations are also incompatible as of this writing,
175especially programs released before summer 1991. The root of the problem is
176that the ISO JPEG committee failed to specify a concrete file format. Some
177vendors "filled in the blanks" on their own, creating proprietary formats that
178no one else could read. (For example, none of the early commercial JPEG
179implementations for the Macintosh were able to exchange compressed files.)
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000180
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000181The file format we have adopted is called JFIF (see REFERENCES). This format
182has been agreed to by a number of major commercial JPEG vendors, and we expect
183that it will become the de facto standard. JFIF is a minimal representation;
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000184work is also going forward to incorporate JPEG compression into the TIFF 6.0
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000185standard, for use in "high end" applications that need to record a lot of
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000186additional data about an image. We intend to support TIFF 6.0 in the future.
187We hope that these two formats will be sufficient and that other, incompatible
188JPEG file formats will not proliferate.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000189
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000190Indeed, part of the reason for developing and releasing this free software is
191to help force rapid convergence to de facto standards for JPEG file formats.
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000192SUPPORT STANDARD, NON-PROPRIETARY FORMATS: demand JFIF or TIFF 6.0!
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000193
194
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000195USING JPEG AS A SUBROUTINE IN A LARGER PROGRAM
196==============================================
197
198You can readily incorporate the JPEG compression and decompression routines in
199a larger program. The file example.c provides a skeleton of the interface
200routines you'll need for this purpose. Essentially, you replace jcmain.c (for
201compression) and/or jdmain.c (for decompression) with your own code. Note
202that the fewer JPEG options you allow the user to twiddle, the less code you
203need; all the default options are set up automatically. (Alternately, if you
204know a lot about JPEG or have a special application, you may want to twiddle
205the default options even more extensively than jcmain/jdmain do.)
206
207Most likely, you will want the uncompressed image to come from memory (for
208compression) or go to memory or the screen (for decompression). For this
209purpose you must provide image reading or writing routines that match the
210interface used by the image file I/O modules (jrdXXX or jwrXXX); again,
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000211example.c shows a skeleton of what is required. In this situation, you
212won't need any of the non-JPEG image file I/O modules used by cjpeg and djpeg.
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000213
214By default, any error detected inside the JPEG routines will cause a message
215to be printed on stderr, followed by exit(). You can override this behavior
216by supplying your own message-printing and/or error-exit routines; again,
217example.c shows how.
218
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000219We recommend you create libjpeg.a as shown in the Makefile, then link that
220with your surrounding program. (If your linker is at all reasonable, only the
221code you actually need will get loaded.) Include the files jconfig.h and
222jpegdata.h in C files that need to call the JPEG routines.
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000223
224CAUTION: some people have tried to compile JPEG and their surrounding code
225with different compilers, e.g., cc for JPEG and c++ or gcc for the rest. This
226is a Real Bad Move and you will deserve what happens to you if you try it.
227(Hint: the parameter structures can get laid out differently with no warning.)
228
229Read our "architecture" file for more info. If it seems to you that the
230software structure doesn't accommodate what you want to do, please contact
231the authors.
232
233Beginning with version 3, we will endeavor to hold the interface described by
234example.c constant, so that you can plug in updated versions of the JPEG code
235just by recompiling. However, we can't guarantee this, especially if you
236choose to twiddle any JPEG options not listed in example.c. Check the
237CHANGELOG when installing any new version, and compare example.c against the
238prior version. Recompile your calling software (don't just relink), as we may
239add or subtract fields in the parameter structures.
240
241
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000242REFERENCES
243==========
244
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000245We highly recommend reading one or more of these references before trying to
246understand the innards of any JPEG software.
247
248The best short technical introduction to the JPEG compression algorithm is
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000249 Wallace, Gregory K. "The JPEG Still Picture Compression Standard",
250 Communications of the ACM, April 1991 (vol. 34 no. 4), pp. 30-44.
251(Adjacent articles in that issue discuss MPEG motion picture compression,
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000252applications of JPEG, and related topics.) If you don't have the CACM issue
253handy, a PostScript file containing a revised version of the article is
254available at ftp.uu.net, graphics/jpeg/wallace.ps.Z. The file (actually a
255preprint for an article to appear in IEEE Trans. Consumer Electronics) omits
256the sample images that appeared in CACM, but it includes corrections and some
257added material. Note: the Wallace article is copyright ACM and IEEE, and it
258may not be used for commercial purposes.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000259
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000260A somewhat less technical, more leisurely introduction to JPEG can be found in
261"The Data Compression Book" by Mark Nelson, published by M&T Books (Redwood
262City, CA), 1991, ISBN 1-55851-216-0. This book provides good explanations and
263example C code for a multitude of compression methods including JPEG. It is
264an excellent source if you are comfortable reading C code but don't know much
265about data compression in general. The book's JPEG sample code is far from
266industrial-strength, but when you are ready to look at a full implementation,
267you've got one here...
268
269A new textbook about JPEG is "JPEG Still Image Data Compression Standard" by
270William B. Pennebaker and Joan L. Mitchell, published by Van Nostrand
271Reinhold, 1993, ISBN 0-442-01272-1. Price US$59.95. This book includes the
272complete text of the ISO JPEG standards (DIS 10918-1 and draft DIS 10918-2).
273This is by far the most complete exposition of JPEG in existence, and I highly
274recommend it. If you read the entire book, you will probably know more about
275JPEG than I do.
276
277The JPEG standard itself is not available electronically; you must order a
278paper copy through ISO. (Unless you are concerned about having a certified
279official copy, I recommend buying the Pennebaker and Mitchell book instead;
280it's much cheaper and includes a great deal of useful explanatory material.)
281In the US, copies of the standard may be ordered from ANSI Sales at (212)
282642-4900. It's not cheap: as of 1992, Part 1 is $95 and Part 2 is $47, plus
2837% shipping/handling. The standard is divided into two parts, Part 1 being
284the actual specification, while Part 2 covers compliance testing methods.
285As of early 1992, Part 1 has Draft International Standard status. It is
286titled "Digital Compression and Coding of Continuous-tone Still Images, Part
2871: Requirements and guidelines" and has document number ISO/IEC DIS 10918-1.
288Part 2 is still at Committee Draft status. It is titled "Digital Compression
289and Coding of Continuous-tone Still Images, Part 2: Compliance testing" and
290has document number ISO/IEC CD 10918-2. (NOTE: I'm told that the final
291version of Part 2 will differ considerably from the CD draft.)
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000292
293The JPEG standard does not specify all details of an interchangeable file
294format. For the omitted details we follow the "JFIF" conventions, revision
Thomas G. Lane88aeed41992-12-10 00:00:00 +00002951.02. A copy of the JFIF spec is available from:
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000296 Literature Department
297 C-Cube Microsystems, Inc.
298 399A West Trimble Road
299 San Jose, CA 95131
300 (408) 944-6300
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000301A PostScript version of this document is available at ftp.uu.net, file
302graphics/jpeg/jfif.ps.Z. It can also be obtained by e-mail from the C-Cube
303mail server, netlib@c3.pla.ca.us. Send the message "send jfif_ps from jpeg"
304to the server to obtain the JFIF document; send the message "help" if you have
305trouble.
306
307The TIFF 6.0 file format specification can be obtained by FTP from sgi.com
308(192.48.153.1), file graphics/tiff/TIFF6.ps.Z; or you can order a printed copy
309from Aldus Corp. at (206) 628-6593. It should be noted that the TIFF 6.0 spec
310of 3-June-92 has a number of serious problems in its JPEG features. A
311clarification note will probably be needed to ensure that TIFF JPEG files are
312compatible across different implementations. The IJG does not intend to
313support TIFF 6.0 until these problems are resolved.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000314
315If you want to understand this implementation, start by reading the
316"architecture" documentation file. Please read "codingrules" if you want to
317contribute any code.
318
319
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000320LEGAL ISSUES
321============
322
323The authors make NO WARRANTY or representation, either express or implied,
324with respect to this software, its quality, accuracy, merchantability, or
325fitness for a particular purpose. This software is provided "AS IS", and you,
326its user, assume the entire risk as to its quality and accuracy.
327
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000328This software is copyright (C) 1991, 1992, Thomas G. Lane.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000329All Rights Reserved except as specified below.
330
331Permission is hereby granted to use, copy, modify, and distribute this
332software (or portions thereof) for any purpose, without fee, subject to these
333conditions:
334(1) If any part of the source code for this software is distributed, then this
335README file must be included, with this copyright and no-warranty notice
336unaltered; and any additions, deletions, or changes to the original files
337must be clearly indicated in accompanying documentation.
338(2) If only executable code is distributed, then the accompanying
339documentation must state that "this software is based in part on the work of
340the Independent JPEG Group".
341(3) Permission for use of this software is granted only if the user accepts
342full responsibility for any undesirable consequences; the authors accept
343NO LIABILITY for damages of any kind.
344
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000345Permission is NOT granted for the use of any IJG author's name or company name
346in advertising or publicity relating to this software or products derived from
347it. This software may be referred to only as "the Independent JPEG Group's
348software".
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000349
350We specifically permit and encourage the use of this software as the basis of
351commercial products, provided that all warranty or liability claims are
352assumed by the product vendor.
353
354
355ansi2knr.c is included in this distribution by permission of L. Peter Deutsch,
356sole proprietor of its copyright holder, Aladdin Enterprises of Menlo Park, CA.
357ansi2knr.c is NOT covered by the above copyright and conditions, but instead
358by the usual distribution terms of the Free Software Foundation; principally,
359that you must include source code if you redistribute it. (See the file
360ansi2knr.c for full details.) However, since ansi2knr.c is not needed as part
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000361of any program generated from the JPEG code, this does not limit you more than
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000362the foregoing paragraphs do.
363
364
365It appears that the arithmetic coding option of the JPEG spec is covered by
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000366patents owned by IBM and AT&T, as well as a pending Japanese patent of
367Mitsubishi. Hence arithmetic coding cannot legally be used without obtaining
368one or more licenses. For this reason, support for arithmetic coding has been
369removed from the free JPEG software. (Since arithmetic coding provides only a
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000370marginal gain over the unpatented Huffman mode, it is unlikely that very many
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000371implementors will support it. If you do obtain the necessary licenses,
Thomas G. Lanebd543f01991-12-13 00:00:00 +0000372contact jpeg-info@uunet.uu.net for a copy of our arithmetic coding modules.)
373So far as we are aware, there are no patent restrictions on the remaining
374code.
375
376
377We are required to state that
378 "The Graphics Interchange Format(c) is the Copyright property of
379 CompuServe Incorporated. GIF(sm) is a Service Mark property of
380 CompuServe Incorporated."
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000381
382
383TO DO
384=====
385
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000386The next major release will probably be a significant rewrite to allow use of
387this code in conjunction with Sam Leffler's free TIFF library (assuming the
388bugs in the TIFF 6.0 specification get resolved).
389
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000390Many of the modules need fleshing out to provide more complete
Thomas G. Lane4a6b7301992-03-17 00:00:00 +0000391implementations, or to provide faster paths for common cases.
Thomas G. Lane88aeed41992-12-10 00:00:00 +0000392Speeding things up is still high on our priority list.
Thomas G. Lane2cbeb8a1991-10-07 00:00:00 +0000393
394We'd appreciate it if people would compile and check out the code on as wide a
395variety of systems as possible, and report any portability problems
396encountered (with solutions, if possible). Checks of file compatibility with
397other JPEG implementations would also be of interest. Finally, we would
398appreciate code profiles showing where the most time is spent, especially on
399unusual systems.
400
401Please send bug reports, offers of help, etc. to jpeg-info@uunet.uu.net.