[OSGeo-Standards] Comments on OGC 12-101 " OGC® Web Coverage Service 2.0 Interface Standard - GeoTIFF Coverage Encoding Extension"
    Even Rouault 
    even.rouault at mines-paris.org
       
    Wed Oct 31 16:29:21 PDT 2012
    
    
  
PART A
1. Evaluator:
        Even Rouault (even dot rouault at mines-paris dot org),
        GDAL/OGR contributor
2. Submission:
    OGC 12-101, "OGC® Web Coverage Service 2.0 Interface Standard - GeoTIFF 
Coverage Encoding Extension"
-----------------------------------------------------
PART B
1. Requirement: #6, "compression" (/req/geotiff-coverage/additional-parameters)
2. Implementation Specification Section number: §6.3.1 GetCoverage request
3. Criticality: Major
4. Comments/justifications for changes:
There are some ambiguities that should be clarified to ensure proper 
understanding and interoperability related on "compression". It is not always 
obvious to correlate the string values of the proposed standard with the 
actual values of the related TIFF compression tag (259). More precisely, :
	* "Huffman" is not the usual way of designating the "Modified Huffman 
Compression" (TIFF compression scheme) of the TIFF6 specification. Even the 
TIFF specification isn't completely consistant in the naming, since this method 
is also called "CCITT 1D" in "Appendix A: TIFF Tags Sorted by Number". In GDAL 
or in libtiff software, it is for example called CCITTRLE. I'm not sure if 
there's an universally agreed way of designating this method, but some 
clarification might be helpfull.
	* "JPEG". There is a high risk of confusion on this one. In TIFF6 
specification, there's a JPEG compression method described, as being the 
compression method number 6. However, this method is only of historical 
revelance, and is now known as the "Old JPEG" in TIFF specification. 
http://www.remotesensing.org/libtiff/TIFFTechNote2.html (which has been mostly 
pasted into 
http://partners.adobe.com/public/developer/en/tiff/TIFFphotoshop.pdf ) explains 
the problems with this original specification, and an alternative method, 
number 7. Producers of JPEG compressed TIFF are highly encouraged to produce 
files using method number 7, and deprecate method 6. This is COMPRESSION_JPEG = 
7 constant of libtiff, and the COMPRESS=JPEG creation option of the GDAL 
GeoTIFF driver.
Related to JPEG compression, the proposed standard doesn't specify which value 
for the Photometric tag the server should use to generate the GeoTIFF. For 3 
bands RGB JPEG-in-TIFF, PhotometricInterpretation = YCbCr or RGB can be used. 
YCbCr leads to higher compression rates (at the expense of some quality loss) 
due to the default subsampling factor of 2 for the Cb and Cr componants. Not 
specifying the photometric interpreation to use (or not offering a parameter to 
the user to specify it) isn't strictly required for this standard to be 
implemented successfully : this lets an implementation choice to the server 
side, and the client side must be able to cope with YCbCr or RGB photometric 
interpretations.
       * "DEFLATE". This method isn't described at all in TIFF6 specification, 
but in http://partners.adobe.com/public/developer/en/tiff/TIFFphotoshop.pdf as 
compression = 8. In libtiff, this corresponds to the following constant : 
COMPRESSION_ADOBE_DEFLATE = 8. Note that libtiff also defines 
COMPRESSION_DEFLATE = 32946, but this is apparently only historical. In GDAL, 
COMPRESS=DEFLATE actually maps to libtiff COMPRESSION_ADOBE_DEFLATE = 8
--> Recommandation 1 : add a mapping between the string in the GML and the 
value of the Compression TIFF tag, like the following table :
	Compression name			Value of Compression TIFF tag
---------------------------------------------------------------------------------------------------------------
	None						1
	PackBits					32773
	Huffman					2
	LZW						5
	JPEG						7 (as in TIFFTechNote2)
	DEFLATE					8
	
--> Recommandation 2 : make it clear that the JPEG in the GeoTIFF Coverage 
Encoding Extension is meant to be the method 7 as in TIFFTechNote 2, inseadd 
of method 6 as in TIFF6.pdf
--> Recommandation 3 : add mention to TIFFTechNote2 and TIFFphotoshop.pdf in 
Bibliography
-----------------------------------------------------
PART B
1. Requirement: #6, "predictor" (/req/geotiff-coverage/additional-parameters)
2. Implementation Specification Section number: §6.3.1 GetCoverage request
3. Criticality: Minor
4. Comments/justifications for changes:
a) It should perhaps be mentionned that "predictor" only makes sense for LZW 
and Deflate compression methods of the proposed standard (references:  
TIFFPhotoshop.pdf page 2, 
http://www.awaresystems.be/imaging/tiff/tifftags/predictor.html ). The later 
page mentions that "Theoretically, the predictor step is independent from the 
compression step, and thus can be combined with any compression scheme", but 
in practice a review of the libtiff code only that is only handled by the 
Deflate, LZW, Pixarlog and LZMA compression methods. I have no strong opinion 
on whether it should be mentionned in an informational note that the 
applicability of predictor is limited to LZW and Deflate , or if this should be 
formalized as a constraint (like jpeg_quality only applicate for 
compression=jpeg).
b) As far as "Floatingpoint" is concerned, this method isn't described in 
TIFF6.pdf. http://www.awaresystems.be/imaging/tiff/tifftags/predictor.html 
mentions that "A third specification supplement from Adobe, that is not yet 
available on-line, defines this new value:  3 = Floating point horizontal 
differencing. ". Actually, I found in 
http://wwwimages.adobe.com/www.adobe.com/content/dam/Adobe/en/products/photoshop/pdfs/dng_spec_1.4.0.0.pdf 
a mention to "3 = Floating Point. Documented in “Adobe Photoshop TIFF 
Technical Note 3” (page 20) and links to http://chriscox.org/TIFFTN3d1.pdf 
"Adobe Photoshop® TIFF Technical Note 3" . This method is implemented in 
libtiff.
-----------------------------------------------------
PART B
1. Requirement: #6 (/req/geotiff-coverage/additional-parameters)
2. Implementation Specification Section number: §6.3.1 GetCoverage request
3. Criticality: Minor
4. Comments/justifications for changes:
There's no apparent consistency rule for the case of the values of the various 
parameters.
- For compression, you have : "None", "PackBits", "Huffman", "LZW", "JPEG", 
"DEFLATE” (mix of UpperCamelCase and upper case).
- For predictor, you have : "None", "Horizontal", "Floatingpoint" (why not 
FloatingPoint ?).
- For interleave, you have "pixel", "band" (lower case)
-----------------------------------------------------
PART B
1. Requirement: #6, "tilewidth" and "tileheight" (/req/geotiff-
coverage/additional-parameters)
2. Implementation Specification Section number: §6.3.1 GetCoverage request
3. Criticality: Minor
4. Comments/justifications for changes:
Perhaps add a note for implementators of the server side that some 
care/validation should be made with large values of those parameters. It is 
possible to generate a 20x20 raster, with for example 65536x65536 tile 
dimensions. This can lead to huge RAM, CPU and temporary storage consumption.
-----------------------------------------------------
PART B
1. Requirement: 
2. Implementation Specification Section number: Documentation of 
"predictorType" in wcsGeotiff.xsd
3. Criticality: Minor
4. Comments/justifications for changes:
The current documentation predictorType is a copy&paste error from the 
documentation of interleaveType
-----------------------------------------------------
PART B
1. Requirement: General
2. Implementation Specification Section number: General
3. Criticality: Minor
4. Comments/justifications for changes:
The proposed standard only refers to "classical" TIFF, which is limited to 
files smaller than 4GB. Has it been considered that BigTIFF 
(http://www.remotesensing.org/libtiff/bigtiffpr.html) could be necessary to 
satisfy some huge requests ? I'm not sure however if this is in the scope of 
WCS to address such requests.
-----------------------------------------------------
PART B
1. Requirement: 
2. Implementation Specification Section number: Annex B Bibliography
3. Criticality: Major
4. Comments/justifications for changes:
Add a link to :
- http://www.remotesensing.org/libtiff/TIFFTechNote2.html : for JPEG 
compression (method 7)
- http://partners.adobe.com/public/developer/en/tiff/TIFFphotoshop.pdf : for 
Deflate compression (method 8)
- http://chriscox.org/TIFFTN3d1.pdf : for Floating-point predictor algorithm
    
    
More information about the Standards
mailing list