ISCE_INSAR/components/isceobj/ScansarProc/runEqualizeSlcs.py

92 lines
2.8 KiB
Python

#
# Author: Piyush Agram
# Copyright 2016
#
import logging
import isceobj
import os
import numpy as np
logger = logging.getLogger('isce.scansarinsar.runCommonRangeSpectra')
def createVirtualCopy(infile, outfile):
'''
Create a virtual copy as is.
'''
from osgeo import gdal
import shutil
ds = gdal.Open(infile + '.vrt', gdal.GA_ReadOnly)
width = ds.RasterXSize
lgth = ds.RasterYSize
ds = None
img = isceobj.createSlcImage()
img.setWidth(width)
img.setLength(lgth)
img.setAccessMode('READ')
img.setFilename(outfile)
img.renderHdr()
##Copy VRT as is
shutil.copyfile( infile + '.vrt', outfile + '.vrt')
def runEqualizeSlcs(self):
'''Align central frequencies and pixel sizes.
'''
swathList = self._insar.getValidSwathList(self.swaths)
catalog = isceobj.Catalog.createCatalog(self._insar.procDoc.name)
print('Common swaths: ', swathList)
for ind, swath in enumerate(swathList):
##Load master swath
master = self._insar.loadProduct( os.path.join(self._insar.commonRangeSpectraMasterSlcProduct,
's{0}.xml'.format(swath)))
##Load slave swath
slave = self._insar.loadProduct( os.path.join(self._insar.commonRangeSpectraSlaveSlcProduct,
's{0}.xml'.format(swath)))
###Check if master needs range filtering
if (np.abs(master.instrument.rangeSamplingRate - slave.instrument.rangeSamplingRate) < 1.0) and ((master.PRF - slave.PRF) < 1.0):
print('No need to equalize pixesl for swath {0}'.format(swath))
####Copy master as is
infile = master.image.filename
outfile = os.path.join(self._insar.equalizedMasterSlcProduct,
's{0}/swath.slc'.format(swath))
os.makedirs( os.path.dirname(outfile))
createVirtualCopy(infile, outfile)
##Generate product
master.image.filename = outfile
self._insar.saveProduct(master, os.path.dirname(outfile) + '.xml')
###Copy slave as is
infile = slave.image.filename
outfile = os.path.join(self._insar.equalizedSlaveSlcProduct,
's{0}/swath.slc'.format(swath))
os.makedirs( os.path.dirname(outfile))
createVirtualCopy(infile, outfile)
##Generate product
slave.image.filename = outfile
self._insar.saveProduct(slave, os.path.dirname(outfile) + '.xml')
else:
raise NotImplementedError("We haven't implemented this yet. Maybe we can get around this. To be explored ...")
catalog.printToLog(logger, "runEqualizeSlcs")
self._insar.procDoc.addAllFromCatalog(catalog)