Skaluj 16 do 8 bitów w zakresie za pomocą GDAL

11

Chcę przeskalować 16-bitowy obraz tiff bez znaku do 8-bitowego obrazu za pomocą GDAL (OSGeo4W). Chcę jednak ograniczyć wartości pikseli, aby pozostawały w zakresie zdjęć 8-bitowych. Chcę przez to powiedzieć, że proporcja wizualna obrazu 16-bitowego jest reprezentowana na obrazie 8-bitowym (0–255). Użycie gdal_translate do konwersji z 16-bitowego na 8-bitowy obcina wartości pikseli i nie tworzy obrazu RGB. Nie jestem pewien, jaką funkcję i ustawienie wywołać z poziomu gdal_translate, czy też jest lepsza opcja.


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
Ryan Garnett
źródło
1
Czy możesz podać szczegółowe informacje na temat rodzaju używanych zdjęć?
Aaron
Na przykład dołączając raport gdalinfo pliku źródłowego. Napisz także dokładne polecenie gdal_translate, którego użyłeś.
user30184,
gdalinfo zostało dodane do pytania jako AKTUALIZACJA. Zdjęcia są zdjęciami stereo 3 poziomu. Użyto polecenia gdal_translate: gdal_translate -ot Byte input.tif output.tif
Ryan Garnett
1
Być może prawdziwe dane z 16-bitowych zdjęć wykorzystują tylko wąski wycinek pełnego zakresu. Sprawdzanie histogramu na przykład za pomocą QGIS może to ujawnić. Możesz także spróbować z parametrem -scale gdal.org/gdal_translate.html . Jeśli wędrujesz wyjściem RGB z 4-pasmowego oryginału, wybierz trzy z nich z parametrami -b, na przykład-b 1 -b 2 -b 3
user30184

Odpowiedzi:

21

Jeśli nie chcesz, aby wartości powyżej 255 zostały obcięte, musisz je zmniejszyć. W tym celu gdal_translate zapewnia opcję -scale:

Z instrukcji :

-scale [src_min src_max [dst_min dst_max]]: przeskaluj wartości pikseli wejściowych z zakresu src_min do src_max do zakresu dst_min do dst_max. W przypadku pominięcia zakres wyjściowy wynosi od 0 do 255. W przypadku pominięcia zakres wejściowy jest automatycznie obliczany na podstawie danych źródłowych.

Więc możesz użyć tego:

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

Dlaczego 255 i 65535?

Masz 2 ^ nbity wartości. Ponieważ minimalna wartość wynosi zwykle 0, maksymalna wartość to 2^nbits-1.

  • 8 bitów -> 2 ^ 8 = 256 wartości -> 0-255
  • 16 bitów -> 2 ^ 16 = 65536 vaues -> 0-65535
pLumo
źródło