/*
* Copyright (C) 2015 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.csa.rstb.classification.gpf;
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.util.TestUtils;
import org.junit.Test;
import java.io.File;
import static org.junit.Assert.assertNotNull;
/**
* Unit test for PolarimetricClassification.
*/
public class TestClassifcationOp {
static {
TestUtils.initTestEnvironment();
}
private final static OperatorSpi spi = new PolarimetricClassificationOp.Spi();
private Product runClassification(final PolarimetricClassificationOp op, final String classifier,
final File inputFile) throws Exception {
if (!inputFile.exists()) {
TestUtils.skipTest(this, inputFile + " not found");
return null;
}
final Product sourceProduct = TestUtils.readSourceProduct(inputFile);
assertNotNull(op);
op.setSourceProduct(sourceProduct);
op.SetClassification(classifier);
// get targetProduct: execute initialize()
final Product targetProduct = op.getTargetProduct();
TestUtils.verifyProduct(targetProduct, true, true, true);
return targetProduct;
}
@Test
public void testCloudePottierClassifier() throws Exception {
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_CLOUDE_POTTIER_CLASSIFICATION, TestData.inputQuad);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_CLOUDE_POTTIER_CLASSIFICATION, TestData.inputQuadFullStack);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_CLOUDE_POTTIER_CLASSIFICATION, TestData.inputC3Stack);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_CLOUDE_POTTIER_CLASSIFICATION, TestData.inputT3Stack);
}
@Test
public void testWishartClassifier() throws Exception {
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_HALPHA_WISHART_CLASSIFICATION, TestData.inputQuad);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_HALPHA_WISHART_CLASSIFICATION, TestData.inputQuadFullStack);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_HALPHA_WISHART_CLASSIFICATION, TestData.inputC3Stack);
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_HALPHA_WISHART_CLASSIFICATION, TestData.inputT3Stack);
}
@Test
public void testTerrainClassifier() throws Exception {
runClassification((PolarimetricClassificationOp) spi.createOperator(),
PolarimetricClassificationOp.UNSUPERVISED_FREEMAN_DURDEN_CLASSIFICATION, TestData.inputQuad);
// runClassification((PolarimetricClassificationOp)spi.createOperator(),
// PolarimetricClassificationOp.UNSUPERVISED_TERRAIN_CLASSIFICATION, TestData.inputQuadFullStack);
// runClassification((PolarimetricClassificationOp)spi.createOperator(),
// PolarimetricClassificationOp.UNSUPERVISED_TERRAIN_CLASSIFICATION, TestData.inputC3Stack);
// runClassification((PolarimetricClassificationOp)spi.createOperator(),
// PolarimetricClassificationOp.UNSUPERVISED_TERRAIN_CLASSIFICATION, TestData.inputT3Stack);
}
}