In [ ]:
import numpy
from snappy import Product, ProductData, ProductIO, ProductUtils, FlagCoding
In [ ]:
infile = '/eodata/Envisat/Meris/FRS/2012/04/08/MER_FRS_1PPEPA20120408_105857_000005063113_00267_52867_0978.N1'
print("Reading...")
product = ProductIO.readProduct(infile)
width = product.getSceneRasterWidth()
height = product.getSceneRasterHeight()
name = product.getName()
description = product.getDescription()
band_names = product.getBandNames()
print("Product: %s, %s" % (name, description))
print("Raster size: %d x %d pixels" % (width, height))
print("Start time: " + str(product.getStartTime()))
print("End time: " + str(product.getEndTime()))
print("Bands: %s" % (list(band_names)))
In [ ]:
b7 = product.getBand('radiance_7')
b10 = product.getBand('radiance_10')
In [ ]:
ndviProduct = Product('NDVI', 'NDVI', width, height)
ndviBand = ndviProduct.addBand('ndvi', ProductData.TYPE_FLOAT32)
ndviFlagsBand = ndviProduct.addBand('ndvi_flags', ProductData.TYPE_UINT8)
writer = ProductIO.getProductWriter('BEAM-DIMAP')
ProductUtils.copyGeoCoding(product, ndviProduct)
ndviFlagCoding = FlagCoding('ndvi_flags')
ndviFlagCoding.addFlag("NDVI_LOW", 1, "NDVI below 0")
ndviFlagCoding.addFlag("NDVI_HIGH", 2, "NDVI above 1")
group = ndviProduct.getFlagCodingGroup()
group.add(ndviFlagCoding)
ndviFlagsBand.setSampleCoding(ndviFlagCoding)
ndviProduct.setProductWriter(writer)
ndviProduct.writeHeader('snappy_ndvi_output.dim')
r7 = numpy.zeros(width, dtype=numpy.float32)
r10 = numpy.zeros(width, dtype=numpy.float32)
print("Writing...")
for y in range(height):
print("processing line ", y, " of ", height)
r7 = b7.readPixels(0, y, width, 1, r7)
r10 = b10.readPixels(0, y, width, 1, r10)
ndvi = (r10 - r7) / (r10 + r7)
ndviBand.writePixels(0, y, width, 1, ndvi)
ndviLow = ndvi < 0.0
ndviHigh = ndvi > 1.0
ndviFlags = numpy.array(ndviLow + 2 * ndviHigh, dtype=numpy.int32)
ndviFlagsBand.writePixels(0, y, width, 1, ndviFlags)
ndviProduct.closeIO()
print("Done.")