/*- * 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 uk.ac.diamond.scisoft.analysis.processing.operations.reflectivityandsxrd; import org.eclipse.dawnsci.analysis.dataset.slicer.SliceFromSeriesMetadata; import org.eclipse.january.dataset.Dataset; import org.eclipse.january.dataset.DatasetUtils; import org.eclipse.january.dataset.IDataset; import uk.ac.diamond.scisoft.analysis.processing.operations.utils.ProcessingUtils; /**This class is generate an array ([2]) datasets of the X-ray flux at given theta values. These are used to correct X-ray reflectivity * measurements * * */ public class RecoverNormalisationFluxBatch { public static Dataset[] normalisationFlux(IDataset input, String path){ SliceFromSeriesMetadata tmp = input.getFirstMetadata(SliceFromSeriesMetadata.class); Dataset flux = null; Dataset theta = null; Dataset[] fluxData = new Dataset[2]; if ((boolean) (path.equalsIgnoreCase("NO") ||(path.equalsIgnoreCase(null)))) { try { flux = DatasetUtils.sliceAndConvertLazyDataset(ProcessingUtils.getLazyDataset(null, tmp.getFilePath(), ReflectivityMetadataTitles.getionc1())); theta = DatasetUtils.sliceAndConvertLazyDataset(ProcessingUtils.getLazyDataset(null, tmp.getFilePath(), ReflectivityMetadataTitles.getqsdcd())); } catch (Exception e){ System.out.println("No normalisation data available internally"); } } else { try{ flux = DatasetUtils.sliceAndConvertLazyDataset(ProcessingUtils.getLazyDataset(null, path, ReflectivityMetadataTitles.getadc2())); theta = DatasetUtils.sliceAndConvertLazyDataset(ProcessingUtils.getLazyDataset(null, path, ReflectivityMetadataTitles.getqdcd_())); } catch (Exception e){ System.out.println("No normalisation data availbale externally"); } } fluxData[0] = theta; fluxData[1]= flux; return fluxData; } } //TEST