¿Cómo resuelvo el error de Gdalwarp 'demasiados puntos no se pudieron transformar' para reasignar geoestacionario a Lambert conforme?

11

Estoy tratando de reasignar de geoestacionario a Lambert conforme usando gdalwarp. Mis datos de entrada están en netcdf, y están en coordenadas geográficas (grados) y me gustaría enviar los datos reasignados a netcdf. He creado un archivo vrt correspondiente para los datos de entrada netcdf. Gdalwarp generará el archivo netcdf, pero los datos de salida son todos ceros y recibo el siguiente error:

Creating output file that is 5120P x 5120L.
Processing input file netcdf.vrt.
ERROR 1: Too many points (441 out of 441) failed to transform,
unable to compute output bounds.
Warning 1: Unable to compute source region for output window 0,0,5120,5120, skipping.
0...10...20...30...40...50...60...70...80...90...100 - done.

Intenté el siguiente comando:

/usr/bin/gdalwarp -s_srs "+proj=geos +h=35785831 +lon_0=-75 +x_0=-0.151844 +y_0=0.151844 +a=6378140 +b=6356754.99999591 +units=degrees +no_defs" -t_srs "+proj=lcc +ellps=clrk66 +a=6378137 +b=6378137 +e=0.0818191910435 +lat_0=24.9999 +lon_0=-95 +lat_1=24.9999 +lat_ts=25.0001 +units=meters +no_defs" -te -1952976.3246 -828316.5944 3248431.6754 4373091.4056 -of netCDF -geoloc -overwrite -r bilinear -ts 5120 5120 netcdf.vrt out.nc

¿Puede gdalwarp reasignar de coordenadas geográficas a proyectadas? ¿O primero necesito traducir geográfico a proyectado? Además, ¿puede gdalwarp leer información de proyección directamente desde netcdf o NECESITA escribir primero a .vrt?

Esto es lo que genera gdalinfo del archivo de entrada: (es un archivo GOES 13 de CLASS)

Size is 512, 512
Coordinate System is `'
Metadata:
  NC_GLOBAL#Conventions=CF-1.4
  NC_GLOBAL#Satellite Sensor=G-13 IMG    
  NC_GLOBAL#Source=McIDAS Area File
Subdatasets:
  SUBDATASET_1_NAME=NETCDF:"goes13.2013.100.165517.BAND_04.nc":auditTrail
  SUBDATASET_1_DESC=[3x80] auditTrail (8-bit character)
  SUBDATASET_2_NAME=NETCDF:"goes13.2013.100.165517.BAND_04.nc":data
  SUBDATASET_2_DESC=[1x665x2036] data (32-bit floating-point)
  SUBDATASET_3_NAME=NETCDF:"goes13.2013.100.165517.BAND_04.nc":lat
  SUBDATASET_3_DESC=[665x2036] lat (32-bit floating-point)
  SUBDATASET_4_NAME=NETCDF:"goes13.2013.100.165517.BAND_04.nc":lon
  SUBDATASET_4_DESC=[665x2036] lon (32-bit floating-point)
Corner Coordinates:
Upper Left  (    0.0,    0.0)
Lower Left  (    0.0,  512.0)
Upper Right (  512.0,    0.0)
Lower Right (  512.0,  512.0)
Center      (  256.0,  256.0)

Y información adicional de gdal sobre la variable de datos:

Driver: netCDF/Network Common Data Format
Files: goes13.2013.100.174518.BAND_04.nc
Size is 2036, 665
Coordinate System is `'
Metadata:
  data#coordinates=lon lat
  data#long_name=0-255 Brightness Temperature
  data#type=VISR
  NC_GLOBAL#Conventions=CF-1.4
  NC_GLOBAL#Satellite Sensor=G-13 IMG    
  NC_GLOBAL#Source=McIDAS Area File
  NETCDF_DIM_EXTRA={time}
  NETCDF_DIM_time_DEF={1,4}
  NETCDF_DIM_time_VALUES=1365615900
  time#long_name=seconds since 1970-1-1 0:0:0
  time#units=seconds since 1970-1-1 0:0:0
Geolocation:
  LINE_OFFSET=0
  LINE_STEP=1
  PIXEL_OFFSET=0
  PIXEL_STEP=1
  SRS=GEOGCS["WGS 84",DATUM["WGS_1984",SPHEROID["WGS 84",6378137,298.257223563,AUTHORITY["EPSG","7030"]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY["EPSG","6326"]],PRIMEM["Greenwich",0,AUTHORITY["EPSG","8901"]],UNIT["degree",0.0174532925199433,AUTHORITY["EPSG","9108"]],AUTHORITY["EPSG","4326"]]
  X_BAND=1
  X_DATASET=NETCDF:"goes13.2013.100.174518.BAND_04.nc":lon
  Y_BAND=1
  Y_DATASET=NETCDF:"goes13.2013.100.174518.BAND_04.nc":lat
Corner Coordinates:
Upper Left  (    0.0,    0.0)
Lower Left  (    0.0,  665.0)
Upper Right ( 2036.0,    0.0)
Lower Right ( 2036.0,  665.0)
Center      ( 1018.0,  332.5)
Band 1 Block=2036x1 Type=Float32, ColorInterp=Undefined
  NoData Value=9.96920996838686905e+36
  Metadata:
    coordinates=lon lat
    long_name=0-255 Brightness Temperature
    NETCDF_DIM_time=1365615900
    NETCDF_VARNAME=data
    type=VISR

¡Cualquier ayuda será apreciada!

Katie J
fuente
1
La proyección geos no usará grados; prueba metros. ¿Dónde obtienes los valores + x_0 / + y_0? Basado en gdalinfo, no estoy seguro de que el ráster de entrada esté georreferenciado en absoluto. En el objetivo srs, tienes + a = + b, que es una esfera, pero también establece + e. Sin embargo, + ellps es para un elipsoide completamente diferente. Los diversos valores + lat también parecen extraños. lat_ts es lat de escala real, por lo que es un paralelo estándar como lat_1.
mkennedy
Gracias. Intentaré usar medidores. Estoy obteniendo x_0 e y_0 (escala y compensaciones) de la definición de GOES, aunque estas no son entradas obligatorias para + proj = geos, por lo que puedo intentar eliminarlas. Y gracias por señalar la adición del elipsoide + e. Las definiciones de lat para t_srs son para la definición AWIPS de lambert (un tamaño de salida específico). Agregaré lo que la información de gdal escupe para la variable de datos específica a la publicación de preguntas (demasiado tiempo para comentar)
Katie J
La definición de AWIPS a la que me refiero se describe en esta página: nws.noaa.gov/noaaport/html/icdtb48_2.html (la primera es la Lambert a la que intento reasignar)
Katie J
1
Hmmm, entonces dice lat / lon WGS84, pero las coordenadas de la esquina informadas me preocupan porque son solo valores de celda sin procesar. El LCC es un caso tangente: un solo paralelo estándar / latitud de origen están todos a 25N. No he trabajado con ninguno de estos datos, así que solo voy por la información de metadatos.
mkennedy
La imagen no está georreferenciada, pero una fuente srs son los suministros. Algunas preguntas: * ¿Se puede ejecutar con CPL_DEBUG = GDAL_netCDF? Entonces CPL_DEBUG = GDAL_netCDF / usr / bin / gdalwarp ... Sospecho que puede haber un problema con las matrices de geolocalización. * ¿Puedes hacer que tus datos estén disponibles?

Respuestas: