将数组合并到栅格(jpeg)

时间:2015-12-19 22:54:59

标签: python image numpy gdal pillow

我整天都在尝试将三个ndarray组合成一张jpeg图片。我使用gdal库提取三个波段。导出的值以数组形式显示,如下所示:

[[ 6355.  6586.  6646. ...,   704.   671.   725.]
 [ 5853.  6031.  6107. ...,   782.   813.   897.]
 [ 4632.  4748.  4305. ...,   837.   869.   802.]
 ..., 
 [ 1032.  1090.  1018. ...,  1500.  1441.  1387.]
 [  958.   980.   913. ...,  1522.  1455.  1391.]
 [  883.   932.   966. ...,  1489.  1369.  1378.]]

这是pix文件中的一个提取带。我有三个乐队。在这里,我正在尝试结合这些乐队:

rgbArray = np.zeros((rows,cols,3), dtype=np.uint8)
band1 = dataset.GetRasterBand(closest_channel(dict_channel, 640)-1)
band2 = dataset.GetRasterBand(closest_channel(dict_channel, 550)-1)
band3 = dataset.GetRasterBand(closest_channel(dict_channel, 460)-1)
data1 = band1.ReadAsArray (0, 0, cols, rows).astype(np.float)
data2 = band2.ReadAsArray (0, 0, cols, rows).astype(np.float)
data3 = band3.ReadAsArray (0, 0, cols, rows).astype(np.float)
rgbArray[..., 0] = data1
rgbArray[..., 1] = data2
rgbArray[..., 2] = data3
img = Image.fromarray(rgbArray, 'RGB')

,图片看起来像这样: enter image description here

当然不是好结果。它应该是从地面上的平面拍照,应该是场地。

我会很高兴任何帮助 非常感谢

1 个答案:

答案 0 :(得分:1)

根据数据的域,将其缩放到[0,255]范围内。

一种天真的方法,就是考虑数据的范围,即信号的最大范围,例如

[...]

data1 = band1.ReadAsArray (0, 0, cols, rows).astype(np.float)

[...]

# Normalize data range
max1 = np.nanmax(data1)
min1 = np.nanmax(data1)

data1 = ((data1 - min1)/(max1 - min1)) * 255

[...]  

rgbArray[..., 0] = data1.astype(int)