/*-
* Copyright 2016 Diamond Light Source Ltd.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*/
package org.dawnsci.surfacescatter;
import java.util.Arrays;
import org.eclipse.dawnsci.analysis.api.processing.OperationData;
import org.eclipse.dawnsci.analysis.api.processing.OperationRank;
import org.eclipse.dawnsci.analysis.dataset.operations.AbstractOperation;
import org.eclipse.january.IMonitor;
import org.eclipse.january.dataset.Dataset;
import org.eclipse.january.dataset.DatasetFactory;
import org.eclipse.january.dataset.DatasetUtils;
import org.eclipse.january.dataset.DoubleDataset;
import org.eclipse.january.dataset.IDataset;
import org.eclipse.january.dataset.IndexIterator;
import org.eclipse.january.dataset.LinearAlgebra;
import org.eclipse.january.dataset.Maths;
import uk.ac.diamond.scisoft.analysis.fitting.functions.Polynomial2D;
/**
* Cuts out the region of interest and fits it with a 2D polynomial background.
*/
public class TwoDFittingUsingIOperation extends AbstractOperation<TwoDFittingModel, OperationData> {
private static Dataset output;
private static Polynomial2D g2;
private static int DEBUG = 0;
private IDataset in1Background;
@Override
public String getId() {
return "uk.ac.diamond.scisoft.surfacescatter.TwoDFittingUsingIOperation";
}
@Override
public OperationRank getInputRank() {
return OperationRank.TWO;
}
@Override
public OperationRank getOutputRank() {
return OperationRank.TWO;
}
@Override
protected OperationData process(IDataset input, IMonitor monitor) {
g2 = null;
int[] len = model.getLenPt()[0];
int[] pt = model.getLenPt()[1];
// debug("pt[0]: " + pt[0] + " pt[1]: " + pt[1] + " in the 2D bg subtraction operation");
Dataset in1 = BoxSlicerRodScanUtilsForDialog.rOIBox(input, len, pt);
if (Arrays.equals(in1.getShape(), new int[] { len[1], len[0] }) == false) {
IDataset location = DatasetFactory.ones(new int[] {2,2});
Dataset errorDat = DatasetFactory.zeros(new int[] { 2, 2 });
// IndexIterator it2 = errorDat.getIterator();
return new OperationData(errorDat, location);
}
if (g2 == null) {
g2 = new Polynomial2D(AnalaysisMethodologies.toInt(model.getFitPower()));
}
if ((int) Math.pow(AnalaysisMethodologies.toInt(model.getFitPower()) + 1, 2) != g2.getNoOfParameters()) {
g2 = new Polynomial2D(AnalaysisMethodologies.toInt(model.getFitPower()));
}
Dataset[] fittingBackground = BoxSlicerRodScanUtilsForDialog.LeftRightTopBottomBoxes(input, len, pt,
model.getBoundaryBox());
if (Arrays.equals(fittingBackground[0].getShape(), (new int[] { 2, 2 }))) {
IDataset location = DatasetFactory.ones(new int[] {2,2});
return new OperationData(fittingBackground[0], location);
}
Dataset matrix = LinearLeastSquaresServicesForDialog.polynomial2DLinearLeastSquaresMatrixGenerator(
AnalaysisMethodologies.toInt(model.getFitPower()), fittingBackground[0], fittingBackground[1]);
DoubleDataset test = (DoubleDataset) LinearAlgebra.solveSVD(matrix, fittingBackground[2]);
double[] params = test.getData();
in1Background = g2.getOutputValues2(params, len, model.getBoundaryBox(),
AnalaysisMethodologies.toInt(model.getFitPower()));
Dataset pBackgroundSubtracted = Maths.subtract(in1, in1Background, null);
output = DatasetUtils.cast(pBackgroundSubtracted, Dataset.FLOAT64);
output.setName("Region of Interest, polynomial background removed");
return new OperationData(output, (IDataset) in1Background);
}
private void debug(String output) {
if (DEBUG == 1) {
System.out.println(output);
}
}
}