Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

COG: add support for INTERLEAVE=BAND and TILE #11541

Merged
merged 2 commits into from
Jan 21, 2025

Conversation

rouault
Copy link
Member

@rouault rouault commented Dec 23, 2024

Fixes #10859

Up to now the COG driver only produced INTERLEAVE=PIXEL / PlanarConfiguration=Contiguous files where values for all bands are in the same tile. This PR add supports for INTERLEAVE=BAND where the tiles of band 1 are placed first, followed by the ones of band 2, etc. It also introduces a INTERLEAVE=TILE mode, which is similar to the BIL (Band Interleave by Line), but generalized to tiles. That is you put first tile (x,y)=(0,0) of band 1, then tile (0, 0) of band 2, ... tile (0, 0) of band N, tile (1, 0) of band 1, ... tile (1, 0) of band N, etc. Both modes can be useful for hyper-spectral datasets for example.

I'm not totally sure about the naming for INTERLEAVE=TILE. Open to suggestions

@rouault rouault force-pushed the gtiff_interleave_tile branch from a00b736 to 2cb6551 Compare December 23, 2024 22:54
@coveralls
Copy link
Collaborator

coveralls commented Dec 23, 2024

Coverage Status

coverage: 70.094% (+0.001%) from 70.093%
when pulling a3d090e on rouault:gtiff_interleave_tile
into 4cc3cd9 on OSGeo:master.

@rouault
Copy link
Member Author

rouault commented Jan 7, 2025

Just FYI @joanma747 (this doesn't violate anything in the OGC COG spec which allow PlanarConfiguration=Separate as a potential option)

@rouault rouault force-pushed the gtiff_interleave_tile branch from 2cb6551 to e4c4770 Compare January 7, 2025 21:36
@rouault
Copy link
Member Author

rouault commented Jan 9, 2025

@jakimowb @tbonfort Any feedback on this PR ? (in particular for the naming of the "TILE" interleaving)

@sgillies
Copy link
Contributor

sgillies commented Jan 9, 2025

@rouault I'm confused about "INTERLEAVE=TILE; COG". Do you intend that there be a semi-colon in the option value or is this just a shorthand way of naming the feature in discussion?

@rouault
Copy link
Member Author

rouault commented Jan 9, 2025

or is this just a shorthand way of naming the feature in discussion?

yes, should read:

  • GTIFF: add INTERLEAVE=TILE
  • COG: add INTERLEAVE=BAND
  • COG: add INTERLEAVE=TILE

Or said differently, with this PR, both GTIFF and COG drivers support INTERLEAVE=PIXEL/BAND/TILE

@tbonfort
Copy link
Member

tbonfort commented Jan 9, 2025

TILE looks good to me for COG. Just to make sure I understand correctly: TILE and BAND are identical for GTIFF, they only differ for COG, right? (the actual layout /may/ differ between TILE/BAND for GTIFF, but said layout is not specified/enforced in this case)

@rouault
Copy link
Member Author

rouault commented Jan 9, 2025

TILE and BAND are identical for GTIFF, they only differ for COG, right? (the actual layout /may/ differ between TILE/BAND for GTIFF, but said layout is not specified/enforced in this case)

Good question. Actually that's a bit subtle. TILE is identical for GTIFF and COG, but for GTIFF, it can only be used in CreateCopy() mode (an error will be emitted at runtime if trying to use it in Create() mode. Also documented at https://github.com/OSGeo/gdal/pull/11541/files#diff-c98fddcda04a8dab184552a28d2b386d941862584daeb6a5b39e9cabdeaaac5dR484). Because in Create() "random" update mode, we can only guarantee the PlanarConfiguration=Separate TIFF setting, and not that the TILE interleaving (which would be dependent on the order users fill blocks, and would require the block cache to honour to be aware of the appropriate order in which to evict dirty blocks).

@tbonfort
Copy link
Member

tbonfort commented Jan 9, 2025

I'm not sure it's a good idea to start introducing layout options for GTIFF : won't we end up implementing a second COG driver? For me TILE should either be unsupported for GTiff, or an exact alias of BAND. This is a nitpick however, not a hill I will die for.

@rouault
Copy link
Member Author

rouault commented Jan 9, 2025

I'm not sure it's a good idea to start introducing layout options for GTIFF : won't we end up implementing a second COG driver?

actually, the COG driver is mostly an empty shell that forwards all the heavy work to the GTiff one, so this has to be supported in some way by the GTiff driver. But I see your point. I could possibly make INTERLEAVE=TILE an undocumented option of the GTiff driver, that only the COG driver would be supposed to make use of it.

@jakimowb
Copy link

@rouault thank you for that implementation. It all looks very good to me, but unfortunately I don't have the possibility to compile and test it locally at the moment.

I like the descriptions that were added to doc/source/drivers/raster/cog.rst and doc/source/drivers/raster/gtiff.rst
To me, they clearly show how the INTERLEAVE=[PIXEL/BAND/TILE] options are meant. Especially the pseudo-code examples are great! They help users like me, with background in hyperspectral remote sensing and more familiar with the terms used by the ENVI driver (INTERLEAVE=[BSQ​/​BIP​/​BIL]), to understand how the COGs are structured.

…RLEAVE=BAND

Fixes OSGeo#10859

Up to now the COG driver only produced INTERLEAVE=PIXEL /
PlanarConfiguration=Contiguous files where values for all bands are in the
same tile. This PR add supports for INTERLEAVE=BAND where the tiles of
band 1 are placed first, followed by the ones of band 2, etc. It also
introduces a INTERLEAVE=TILE mode, which is similar to the BIL
(Band Interleave by Line), but generalize to tiles. That is you put first
tile (x,y)=(0,0) of band 1, then tile (0, 0) of band 2, ... tile (0, 0) of
band N, tile (1, 0) of band 1, ... tile (1, 0) of band N, etc. Both modes
can be useful for hyper-spectral datasets for example.
@rouault rouault force-pushed the gtiff_interleave_tile branch from e4c4770 to a3d090e Compare January 10, 2025 14:50
@rouault rouault changed the title GTiff/COG: add support for INTERLEAVE=TILE; COG: add support for INTERLEAVE=BAND COG: add support for INTERLEAVE=BAND and TILE Jan 10, 2025
@rouault
Copy link
Member Author

rouault commented Jan 10, 2025

I could possibly make INTERLEAVE=TILE an undocumented option of the GTiff driver, that only the COG driver would be supposed to make use of it.

I've just done that

@csaybar
Copy link

csaybar commented Jan 19, 2025

Hi @rouault, thanks for adding this fantastic feature! It’s quite helpful for working with hyperspectral data on cloud storage. While compiling GDAL, I encountered an error, and I wanted to share it here in case it helps others who might be trying the same.

Once again, thank you so much! 🙇‍♂️

General Info

cesar@jordi-Katana-GF66-12UC:~$ cat /etc/os-release
PRETTY_NAME="Ubuntu 22.04.5 LTS"
NAME="Ubuntu"
VERSION_ID="22.04"
VERSION="22.04.5 LTS (Jammy Jellyfish)"
VERSION_CODENAME=jammy
ID=ubuntu
ID_LIKE=debian
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
UBUNTU_CODENAME=jammy

GDAL requirements

cesar@jordi-Katana-GF66-12UC:~$ echo "CMake: $(cmake --version | head -n 1)" && echo "GCC: $(gcc --version | head -n 1)" && echo "G++: $(g++ --version | head -n 1)" && echo "PROJ: $(proj 2>&1 | head -n 1)" 
CMake: cmake version 3.22.1
GCC: gcc (Ubuntu 12.3.0-1ubuntu1~22.04) 12.3.0
G++: g++ (Ubuntu 11.4.0-1ubuntu1~22.04) 11.4.0
PROJ: Rel. 9.4.0, March 1st, 2024

Message

https://pastebin.com/raw/useNe6TJ (All compiling details)

[ 87%] Building CXX object gcore/mdreader/CMakeFiles/gcore_mdreader.dir/reader_spot.cpp.o
[ 87%] Built target gcore_mdreader
[ 87%] Linking CXX shared library libgdal.so
/usr/bin/ld: ogr/CMakeFiles/ogr.dir/ogrspatialreference.cpp.o: in function `OGRSpatialReference::HasPointMotionOperation() const':
ogrspatialreference.cpp:(.text+0x17d7d): undefined reference to `proj_crs_has_point_motion_operation'
/usr/bin/ld: ogr/CMakeFiles/ogr.dir/ogrct.cpp.o: in function `OGRProjCT::Initialize(OGRSpatialReference const*, char const*, OGRSpatialReference const*, char const*, OGRCoordinateTransformationOptions const&)':
ogrct.cpp:(.text+0x347d): undefined reference to `proj_coordinate_metadata_create'
/usr/bin/ld: ogrct.cpp:(.text+0x34ca): undefined reference to `proj_coordinate_metadata_create'
collect2: error: ld returned 1 exit status
gmake[2]: *** [CMakeFiles/GDAL.dir/build.make:2913: libgdal.so.36.3.11.0] Error 1
gmake[1]: *** [CMakeFiles/Makefile2:4150: CMakeFiles/GDAL.dir/all] Error 2
gmake: *** [Makefile:146: all] Error 2

@rouault
Copy link
Member Author

rouault commented Jan 20, 2025

I encountered an error

@csaybar I suspect your error might be that you have 2 versions of PROJ on your system and GDAL builds against the header of a rather recent one but links against the older one.

@rouault rouault added this to the 3.11.0 milestone Jan 21, 2025
@rouault rouault merged commit 3bdc81a into OSGeo:master Jan 21, 2025
38 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add INTERLEAVE=BAND option to COG driver
6 participants