/* * Copyright (C) 2014 by Array Systems Computing Inc. http://www.array.ca * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 3 of the License, or (at your option) * any later version. * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, see http://www.gnu.org/licenses/ */ package org.esa.s1tbx.calibration.gpf; import org.esa.s1tbx.commons.S1TBXTests; import org.esa.s1tbx.commons.TestData; import org.esa.snap.core.datamodel.Product; import org.esa.snap.core.gpf.OperatorSpi; import org.esa.snap.engine_utilities.gpf.TestProcessor; import org.esa.snap.engine_utilities.util.TestUtils; import org.junit.Before; import org.junit.Test; import java.io.File; import static org.junit.Assert.assertNotNull; /** * Unit test for Calibration Operator. */ public class TestCalibrationOp { static { TestUtils.initTestEnvironment(); } private final static OperatorSpi spi = new CalibrationOp.Spi(); private TestProcessor testProcessor; private String[] productTypeExemptions = {"_BP", "XCA", "RAW", "WVW", "WVI", "WVS", "WSS", "OCN", "DOR", "GeoTIFF", "SCS_U"}; private String[] exceptionExemptions = {"not supported", "calibration has already been applied", "The product has already been calibrated", "Cannot apply calibration to coregistered product", "WV is not a valid acquisition mode from: IW,EW,SM" }; @Before public void setUp() { testProcessor = S1TBXTests.createS1TBXTestProcessor(); } @Test public void testProcessingASAR_WSM() throws Exception { final float[] expected = new float[] {0.027908697724342346f, 0.019894488155841827f, 0.020605698227882385f}; processFile(TestData.inputASAR_WSM, "sigma0_VV", expected); } @Test public void testProcessingASAR_IMS() throws Exception { final float[] expected = new float[] {0.043132662773132324f, 3.3039296977221966E-4f, 0.06897620856761932f}; processFile(TestData.inputASAR_IMS, "sigma0_VV", expected); } @Test public void testProcessingERS_IMP() throws Exception { final float[] expected = new float[] {0.19550558924674988f, 0.19353462755680084f, 0.1338571310043335f}; processFile(TestData.inputERS_IMP, "sigma0_VV", expected); } @Test public void testProcessingERS_IMS() throws Exception { final float[] expected = new float[] {0.11003237217664719f, 0.09509188681840897f, 0.01090210024267435f}; processFile(TestData.inputERS_IMS, "sigma0_VV", expected); } @Test public void testProcessingS1_GRD() throws Exception { final float[] expected = new float[] {2.3076418642631324E-7f,2.3079778088685998E-7f,3.255083242947876E-7f}; processFile(TestData.inputS1_GRD, "sigma0_VV", expected); } @Test public void testProcessingS1_StripmapSLC() throws Exception { final float[] expected = new float[] {0.03302580863237381f,0.12401964515447617f,0.3184557855129242f}; processFile(TestData.inputS1_StripmapSLC, "sigma0_VV", expected); } /** * Processes a product and compares it to processed product known to be correct * * @param inputFile the path to the input product * @param bandName the target band name to verify * @param expected expected values * @throws Exception general exception */ private void processFile(final File inputFile, final String bandName, final float[] expected) throws Exception { if (!inputFile.exists()) { TestUtils.skipTest(this, inputFile + " not found"); return; } final Product sourceProduct = TestUtils.readSourceProduct(inputFile); final CalibrationOp op = (CalibrationOp) spi.createOperator(); assertNotNull(op); op.setSourceProduct(sourceProduct); // get targetProduct: execute initialize() final Product targetProduct = op.getTargetProduct(); TestUtils.verifyProduct(targetProduct, true, true, true); TestUtils.comparePixels(targetProduct, bandName, expected); } @Test public void testProcessAllASAR() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsASAR, "ENVISAT", productTypeExemptions, null); } @Test public void testProcessAllERS() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsERS, "ERS CEOS", productTypeExemptions, null); } @Test public void testProcessAllALOS() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsALOS, "ALOS PALSAR CEOS", productTypeExemptions, null); } @Test public void testProcessAllRadarsat2() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsRadarsat2, "RADARSAT-2", productTypeExemptions, null); } @Test public void testProcessAllCosmo() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsCosmoSkymed, "CosmoSkymed", productTypeExemptions, exceptionExemptions); } @Test public void testProcessAllTSX() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsTerraSarX, "TerraSarX", productTypeExemptions, exceptionExemptions); } @Test public void testProcessAllSentinel1() throws Exception { testProcessor.testProcessAllInPath(spi, S1TBXTests.rootPathsSentinel1, "SENTINEL-1", productTypeExemptions, exceptionExemptions); } }