[gdal-dev] Change in behavior in GDAL 3.10.1

Even Rouault even.rouault at spatialys.com
Fri Mar 14 16:35:11 PDT 2025


Tim,

good catch. Fix queued in https://github.com/OSGeo/gdal/pull/11966. The 
FlushCache() workaround is a safe one.

Even

Le 14/03/2025 à 19:37, Tim Harris via gdal-dev a écrit :
> I ran into sort of an odd problem with some rasterization code that 
> changed between 3.10.0 and 3.10.1. The problem also exists with 
> 3.10.2. The core of the problem is flushing data to disk but it seems 
> that threading and compression also have something to do with it.
>
> Here's a way to reproduce it... simple made up geometry first, call it 
> box.geojson:
>
> ---
> {
>   "type": "FeatureCollection",
>   "features": [
>     {
>       "type": "Feature",
>       "geometry": {
>         "type": "Polygon",
>         "coordinates": [
>           [
>             [ 0.25, 0.25 ],
>             [ 0.75, 0.25 ],
>             [ 0.75, 0.75 ],
>             [ 0.25, 0.75 ],
>             [ 0.25, 0.25 ]
>           ]
>         ]
>       }
>     }
>   ]
> }
> ---
>
> Here's the script:
> ---
> from osgeo import gdal, osr
>
> gdal.UseExceptions()
> gdal.SetConfigOption("GDAL_NUM_THREADS", "8")
>
> ds_aoi = gdal.OpenEx("box.geojson")
>
> drv = gdal.GetDriverByName("GTiff")
> ds_out = drv.Create("test.tif",
>                     xsize=100,
>                     ysize=100,
>                     bands=1,
>                     eType=gdal.GDT_Byte,
>                     options=[
>                         "COMPRESS=DEFLATE"
>                     ])
> ds_out.SetGeoTransform((0.0, 0.01, 0.0, 1.0, 0.0, -0.01))
> srs = osr.SpatialReference()
> srs.ImportFromEPSG(4326)
> ds_out.SetSpatialRef(srs)
> srs = None
>
> # Uncomment this and it works...
> # ds_out.FlushCache()
>
> result = gdal.Rasterize(ds_out,
>                         ds_aoi,
>                         burnValues=[1],
>                         bands=[1],
>                         allTouched=True,
>                         callback=gdal.TermProgress)
> print(f"result = {result}")
>
> ds_aoi = None
> ds_out = None
> ---
>
> Run that script, and it will generate a blank TIF and print "result = 
> 0" if using GDAL 3.10.1 or 3.10.2. But if using 3.10.0, it prints 
> "result = 1" and the output looks as expected, a TIF with a box of 1s 
> in the middle of it and 0s around the outside.
>
> Side note... it's also weird that the gdal.Rasterize doesn't seem to 
> throw any exception, but I'm not even sure what the problem is. I 
> tried CPL_DEBUG=ON and don't see anything obvious:
> ---
> GeoJSON: First pass: 100.00 %
> GDAL: GDALOpen(box.geojson, this=0x356de0d0) succeeds as GeoJSON.
> GDAL: GDALDriver::Create(GTiff,test.tif,100,100,1,Byte,0x357529a0)
> GTiff: Using up to 8 threads for compression/decompression
> GDAL: GDAL_CACHEMAX = 799 MB
> GDAL: Rasterizer operating on 1 swaths of 100 scanlines.
> 0result = 0
> GDAL: GDALClose(box.geojson, this=0x356de0d0)
> GTIFF: Waiting for worker job to finish handling block 0
> GDAL: GDALClose(test.tif, this=0x35ab1d80)
> ---
>
> It seems that this combination is required to produce the error:
> - Set GDAL_NUM_THREADS
> - Specify COMPRESS in the GTiff creation options
> - Do NOT flush the cache or close the file between creation and 
> rasterization
>
> If any of those conditions are changed, it appears to work ok.
>
> Is this expected? Is that FlushCache call supposed to be necessary? 
> It's odd that it wasn't required before, but it is now.
>
> _______________________________________________
> gdal-dev mailing list
> gdal-dev at lists.osgeo.org
> https://lists.osgeo.org/mailman/listinfo/gdal-dev

-- 
http://www.spatialys.com
My software is free, but my time generally not.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/gdal-dev/attachments/20250315/478faf8c/attachment.htm>


More information about the gdal-dev mailing list