gdalwarp [--help-general] [--formats]
[-s_srs srs_def] [-t_srs srs_def] [-to "NAME=VALUE"]
[-order n | -tps | -rpc | -geoloc] [-et err_threshold]
[-refine_gcps tolerance [minimum_gcps]]
[-te xmin ymin xmax ymax] [-tr xres yres] [-tap] [-ts width height]
[-ovr level|AUTO|AUTO-n|NONE] [-wo "NAME=VALUE"] [-ot Byte/Int16/...] [-wt Byte/Int16]
[-srcnodata "value [value...]"] [-dstnodata "value [value...]"] -dstalpha
[-r resampling_method] [-wm memory_in_mb] [-multi] [-q]
[-cutline datasource] [-cl layer] [-cwhere expression]
[-csql statement] [-cblend dist_in_pixels] [-crop_to_cutline]
[-of format] [-co "NAME=VALUE"]* [-overwrite]
[-nomd] [-cvmd meta_conflict_value] [-setci] [-oo NAME=VALUE]*
srcfile* dstfile
参考:http://www.gdal.org/gdalwarp.htmlhtml
目标:提升warp的执行效率。sql
原理:express
主要是调整同样变形参数,在-wo、-co中设置。缓存
设置INIT_DEST :INIT_DEST=[value]or INIT_DEST=NO_DATA表示初始化目标文件,若是不设置,则读取源文件并覆盖。多线程
设置多线程数:NUM_THREADS(>=1.10),NUM_THREADS=N表示使用的线程数,若是N=ALL_CPUS则使用所有CPU。工具
增长缓存大小:GDAL_CACHEMAX:用于IO的缓存大小,越大则读写越快;-wm:用于中间操做缓存,越大则单次处理的数据量越大,可是若是每次处理的数据都很小,仍是会按此值进行单次读写,因此会致使效率变慢,此值应该视状况设定。测试
提升精确度:-co TILED=YES,在输出为GeoTiff时,若是设置TILED表示将整个图形由不一样的块组成;若是不设置,则默认将整个图形由单同样条组成(strip)组成;块的精度比单同样条高。官方建议尽可能使用此选项。ui
参考:http://en.wikipedia.org/wiki/Tagged_Image_File_Formatspa
http://trac.osgeo.org/gdal/wiki/UserDocs/GdalWarp#GeoTIFFoutputUse-coTILEDYESwhenpossible线程
方法:
gdalwarp
-wo set a warp option.能够有多个-wo。
示例:
gdalwarp world_4326.tif out.tif -t_srs EPSG:3857-overwrite –wo NUM_THREADS=4-wm 512
参考:
http://www.gdal.org/structGDALWarpOptions.html#a0ed77f9917bb96c7a9aabd73d4d06e08
http://lists.osgeo.org/pipermail/gdal-dev/2013-January/035217.html
http://trac.osgeo.org/gdal/wiki/FAQRaster#Howtoimprovegdalwarpperformance
目的:根据源图像和源坐标系统,输出指定坐标系统的目标图像。
原理:根据源坐标系统和目的坐标系统之间的数学关系,对源图像进行逐点从新采样,生成目标图像。
方法:gdalwarp(直接投影效率很高)
-overwrite 若是目标图像已经存在,则重写(覆盖)。
-s_srs 源坐标系统
-t_srs 目标坐标系统。能够识别EPSG、PROJ4或者wkt的prj文件。
-r 重采样方法near:最邻近值(默认,最快,质量差),bilinear:双线性内插(用的较多),Cubic:三次方,Cubic Spline:三次样条,Lanczos,Average,mode:出现次数最多。
-wm warp caching memory,缓存大小(单位:MB)
-ts target size,目标图像大小,格式:宽高,单位(像素)。不能与-tr共存。
-multi 多线程
-dstnodata 目标图像无值时填充值
-q quiet 不显示进度等处理信息
-cutline 指定裁剪的mask矢量图层
-dstalpha 指定透明通道,对于无数据值的像素设置为透明。
-of output format,指定输出目标图像格式。默认为GeoTiff(GTiff)。
最后两个参数分别是源图像和目标图像。
注意:若是要设置-te,制定输出图像的范围,则使用的是输出图像的坐标系统。若是要使用输入图像的坐标系统,则应该在投影以前生成规定范围的输入图像。
注意:若是在输出图像中不但愿看到黑边(由于图像变形,产生扇形图像,最是会出现无值部分),能够设置-dstalpha使无值部分透明。
注意:若是使用vrt对不一样分辨率图像先进行合成,再投影,有可能出现多个黑线(在图像中间)。生成这种问题的缘由多是因为分块重采样进行投影,可是double精度不足,形成合成时出现无值黑线。解决的方法是先合成独立图像,再进行投影。
示例:
gdalwarp -overwrite -s_srs EPSG:4326 -t_srsEPSG:32650 -r bilinear -wm 20 -ts 3000 3000 -multi -dstnodata 0 -q -cutlineD:/qgis-ppt/grid/grid-polygon.shp -dstalpha -of GTiffD:/qgis-ppt/timeextent/Korea/Korea.png D:/qgis-ppt/timeextent/Korea/ttttt.tif
示例:proj4格式的坐标系统:
gdalwarp -overwrite -s_srs EPSG:4326 -t_srs"+proj=longlat +a=6378137.0000 +rf=298.2572221010000 +towgs840,0,0,0,0,0,0 +no_defs"
目的:根据指定的矢量图形,输出源图像的相应图像。
原理:根据指定的矢量范围(Rectangle),对源图像进行逐点从新采样,Rectangle中无矢量的部分为无数据,有矢量的部分为源图像数据,以今生成目标图像。
方法:gdalwarp
参见:投影
-crop_to_cutline 将目标图像的范围指定为cutline 矢量图像的范围。
示例:
gdalwarp -dstnodata 0 -q –cutline D:/qgis-ppt/vector-cut/cutpolygon.shp-crop_to_cutline -dstalpha -of GTiff D:/qgis-ppt/timeextent/Korea/test.tifD:/qgis-ppt/vector-cut/clipper-poly-alpha.tif
目的:将多个图像合并输出到目标图像。
原理:经过复制原始图像(或者重采样以后再复制)到目标图像。
方法:gdalwarp
输入图像为多个,最后一个为输出图像。
注意:若是效率不够,能够尝试使用gdal_merge.py。使用vrt也能够提升效率。
注意:后加入的图像会覆盖先前的图像范围。
注意:若是输入文件分辨率不一样,默认按照最高分辨率进行重采样。
注意:若是使用vrt文件,输入文件分辨率不一样时,vrt默认使用平均分辨率。应该手动设置为最高分辨率。
示例:
gdalwarp -s_srs EPSG:4326 -t_srs EPSG:4326 -of GTiffD:/qgis-ppt/mosaic/J1.tif D:/qgis-ppt/mosaic/J2.tif D:/qgis-ppt/mosaic/J3.tifD:/qgis-ppt/mosaic/J4.tif D:/qgis-ppt/mosaic/merge4_by_warp.tif
示例:覆盖测试
gdalwarp 5-19-26.jpg 7-77-105.jpg 57.tif
gdalwarp 7-77-105.jpg 5-19-26.jpg 75.tif
目的:根据指定地理范围,获取源图像相应图像。
原理:根据指定的地理范围,从源图像的中copy数据到目标图像。
注意:此方法与gdalbuildvrt结果类似,会更改地图范围(进行重采样)。
注意:使用vrt时,若是在输入文件分辨率不一样时,结果可能出现多条黑线(由于分块进行合成,各块均进行偏移,致使部分范围无数据)。若是分辨率不一样,只能先进行合成,再使用translate进行裁剪。
方法:gdalwarp
-texmin ymin xmax ymax。设置目标坐标系统的范围。
示例:
gdalwarp -s_srs EPSG:4326 -t_srs EPSG:4326 -te114.01 39.97 114.03 39.99 -of GTiff -of GTiff D:/qgis-ppt/mosaic/J1.tifD:/qgis-ppt/mosaic/J2.tif D:/qgis-ppt/mosaic/J3.tif D:/qgis-ppt/mosaic/J4.tifD:/qgis-ppt/mosaic/mcp.tif
目的:更改原始图像的分辨率。
原理:从新采样后,复制到目标图像。
方法:gdalwarp
-trxres yres。设置目标图像的分辨率。不可与-ts共存。
注意:使用vrt时,若是多个相同分辨率的输入图像,则合成时左上角不变,右下角会有一个像素(最终分辨率)的缩放。
注意:使用vrt时,(不管何种采样方法)右下角可能出现无值黑线。此时,可使用-dstalpha将黑线部分透明(增长透明波段,文件体积增大25%)。
示例:
gdalwarp -s_srs EPSG:4326 -t_srs EPSG:4326 -te114.01 39.97 114.03 39.99 -tr 0.000021457672119 -0.000021457672119 -of GTiff D:/qgis-ppt/mosaic/J1.tifD:/qgis-ppt/mosaic/J2.tif D:/qgis-ppt/mosaic/J3.tif D:/qgis-ppt/mosaic/J4.tifD:/qgis-ppt/mosaic/mcp-tr.tif
目的:更改原始图像的分辨率,并以指定重采样方法生成目标图像。
原理:对原始图像逐像素重采样,生成目录图像。
方法:
gdalwarp -ts –r :不会有黑线产生,但有可能缺乏一个像素。推荐使用。
或gdalwarp –tr–r –dstalpha :可能有黑线产生。不推荐使用。
-dstalpha使黑线透明。
示例:
gdalwarp -rbilinear -dstalpha -tr 0.0006 0.0006 output/mix-res.vrt output/mix.tif
gdalwarp -rbilinear -dstalpha –ts 300 300output/mix-res.vrt output/mix.tif
压缩格式和worldfile等输出选项都与输出格式相关联,须要在输出格式中指定co(create operateion)选项。
注意:GeoTiff的JPEG压缩与-dstalpha没法共存。
目的:输出带有worldfile(TFW)的,通过压缩的tiff文件。
方法:gdalwarp
–co TFW=YES 输出WORLDFILE文件
–co COMPRESS=JPEG 使用JPEG压缩,支持如下压缩格式:[JPEG/LZW/PACKBITS/DEFLATE/CCITTRLE/CCITTFAX3/CCITTFAX4/NONE],在使用JPEG时,能够设置压缩率(-co JPEG_QUALITY=[1-100]),默认是75%。
–co TILED=YES 使用分块混合,若是不设置则默认使用strip。
示例:
gdalwarp -co TFW=YES -co COMPRESS=JPEG -coTILED=YES output/12.vrt output/12.tif
目的:输出JPEG格式文件,而且要带有worldfile(.wld)文件。
原理:JPEG不能直接由Warp生成,须要先由warp生成geotiff,而后由translate转化为jpeg。
方法:gdalwarp –of VRT 生成vrt格式的中间文件,再由
gdal_translate –of JPEG生成JPEG格式的输出文件,-co WORLDFILE=YES输出worldfile文件,-quality=【10-100】能够设置压缩率(超过95%则没法提升品质,只会增长文件大小),默认是75%。
示例:
gdalwarp -of VRT output/12.vrt output/12-3.vrt
gdal_translate -of JPEG -co WORLDFILE=YESoutput/12-3.vrt output/12-3.jpg
32系统存在2G内存上限,但可能产生不少内存碎片。这些碎片使程序没法申请到大块内存。这种状况下,应该减小缓存值,或者使用64位程序或者不使用--config GDAL_CACHEMAX xxx -wm xxx这两个选项。
参考:http://trac.osgeo.org/gdal/wiki/UserDocs/GdalWarp#Errorallocatingmemory