Scala da 16 bit a 8 bit nel raggio d'azione usando GDAL


11

Sto cercando di ridimensionare un'immagine tiff senza segno a 16 bit a un'immagine a 8 bit utilizzando GDAL (OSGeo4W). Tuttavia, voglio limitare i valori dei pixel in modo che rimangano all'interno dell'intervallo delle immagini a 8 bit. Voglio dire, voglio garantire che la proporzione visiva nell'immagine a 16 bit sia rappresentata nell'immagine a 8 bit (0-255). L'uso di gdal_translate per convertire da 16 bit a 8 bit riduce i valori dei pixel e non produce un'immagine RGB. Non sono sicuro di quale funzione e impostazione chiamare da gdal_translate o se esiste un'opzione migliore.


GDALINFO

C:\>gdalinfo C:\Projects\Stormwater\ForPCI\images\1537TORO_6cm_04761_RGBI.tif
Driver: GTiff/GeoTIFF
Files: C:\Projects\Stormwater\ForPCI\images\1537TORO_6cm_04761_RGBI.tif
Size is 17310, 11310
Coordinate System is `'
Metadata:
  TIFFTAG_DATETIME=2015:05:03 12:27:13
  TIFFTAG_IMAGEDESCRIPTION=UltraCam-Lvl03
--------------
CAM_ID: UC-SXp-1-50215465 [3]
IMG_NO: 4761
RECORD_GUID: 8fc3d7a9-d2e5-40e5-babf-939f1f803dcf
IMG_GUID: C850D0A4-39CA-4BC8-ACD7-81A363D78C6E
FILE_GUID: 86C4F8E4-A2FD-43FB-B3B1-4C4ED8DF0E42
LICENSE_ID: 820342819
SOFTWARE: UltraCam Aerial Radiometry Core 12.6.1408.2501
PIXEL_SIZE_WIDTH: 6 [micron]
PIXEL_SIZE_HEIGHT: 6 [micron]
APERTURE: F_8
EXPOSURE_TIME: 0.002000000000 [s]
HIGH_ISO_MODE_CAPTURE: off
HIGH_ISO_MODE_PROCESSING: off

----- Inner Orientation -----
PRINCIPAL_DISTANCE: 100.500000000000 [mm]
PRINCIPAL_POINT_X: -0.000000000000 [mm]
PRINCIPAL_POINT_Y: 0.180000000000 [mm]
SENSOR_AREA_WIDTH: 103.860000000000 [mm]
SENSOR_AREA_HEIGHT: 67.860000000000 [mm]
-----------------------------

----- Exposure Annotation Data -----
MID_EXPOSURE_CORRECTION: 0.000762000000 [s]
FMS_SENSOR_CODE: UCXp
FMS_CAMERA_PORT: 1
FMS_EXPOSURE_NUMBER: 4761
FMS_PROJECT: 1537TORO
FMS_AREA: 1537TORO_6cm_6030
FMS_LINE_NUMBER: 47
FMS_SEGMENT_NUMBER: 1
FMS_WAY_POINT_NUMBER: 0
GPS_DATE: 150412
GPS_TIME: 162517
GPS_LATITUDE: N43.745319 [degree]
GPS_LONGITUDE: W079.358953 [degree]
GPS_ALTITUDE: 1159 [m]
GPS_POSITION_SOLUTION: GPS
GPS_TRACK_OVER_GROUND: 73 [degree]
GPS_ABOVE_GROUND_LEVEL: 1008.7 [m]
GPS_GROUND_SPEED: 80.4 [mps]
------------------------------------

----- Level-3 Parameters -----
IMG_TYPE: High resolution multi channel RGBI
ROTATION: 0 [degree]
------------------------------------
TIFFTAG_RESOLUTIONUNIT=1 (unitless)
TIFFTAG_SOFTWARE=UltraCam Aerial Radiometry Core 12.6.1408.2501
Image Structure Metadata:
INTERLEAVE=PIXEL
Corner Coordinates:
Upper Left  (    0.0,    0.0)
Lower Left  (    0.0,11310.0)
Upper Right (17310.0,    0.0)
Lower Right (17310.0,11310.0)
Center      ( 8655.0, 5655.0)
Band 1 Block=17310x1 Type=UInt16, ColorInterp=Red
Band 2 Block=17310x1 Type=UInt16, ColorInterp=Green
Band 3 Block=17310x1 Type=UInt16, ColorInterp=Blue
Band 4 Block=17310x1 Type=UInt16, ColorInterp=Undefined

1
Potresti fornire alcuni dettagli sul tipo di immagini che stai utilizzando?
Aaron

Ad esempio allegando il rapporto gdalinfo del file sorgente. Scrivi anche il comando esatto gdal_translate che hai usato.
user30184

gdalinfo è stato aggiunto alla domanda come AGGIORNAMENTO. Le immagini sono immagini stereo di livello 3. Il comando gdal_translate utilizzato era: gdal_translate -ot Byte input.tif output.tif
Ryan Garnett

1
Forse i dati reali delle immagini a 16 bit utilizzano solo una porzione ristretta dell'intero intervallo. Il controllo dell'istogramma con, ad esempio, QGIS può rivelarlo. Puoi anche provare con il parametro -scale gdal.org/gdal_translate.html . Se si utilizza un'uscita RGB da 4 bande originali, selezionarne tre con parametri -b, ad esempio-b 1 -b 2 -b 3
user30184

Risposte:


21

Se non si desidera tagliare i valori superiori a 255, è necessario ridimensionarli. A tale scopo gdal_translate fornisce l'opzione -scale:

Dal manuale :

-scale [src_min src_max [dst_min dst_max]]: ridimensiona i valori dei pixel di input dall'intervallo src_min a src_max nell'intervallo da dst_min a dst_max. Se omesso, l'intervallo di output è compreso tra 0 e 255. Se omesso, l'intervallo di input viene calcolato automaticamente dai dati di origine.

Quindi quello che puoi usare è il seguente:

gdal_translate -of GTiff -ot Byte -scale 0 65535 0 255 src_dataset dst_dataset

Perché 255 e 65535?

Hai valori di 2 ^ nbit. Poiché il valore minimo è in genere 0, il valore massimo è 2^nbits-1.

  • 8 bit -> 2 ^ 8 = 256 valori -> 0-255
  • 16 bit -> 2 ^ 16 = 65536 vaues -> 0-65535
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.