/*-
*******************************************************************************
* Copyright (c) 2011, 2014 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
*
* Contributors:
* Matthew Gerring - initial API and implementation and/or initial documentation
*******************************************************************************/
package uk.ac.diamond.scisoft.analysis.histogram.functions;
/**
* Geographical Green channel mapping
*/
public class GeoGreenMapFunction extends AbstractMapFunction {
private static final double region1 = 1.0/7.0;
private static final double region2 = 1.0/5.0;
private static final double region3 = 1.0/3.0;
private static final double region4 = 2.0/5.0;
private static final double region5 = 2.0/3.0;
private static final double region6 = 5.0/6.0;
@Override
public String getMapFunctionName() {
return "GeoGreen";
}
@Override
public double mapFunction(double input) {
if (input < region1)
return 0;
else if (input >= region1 && input < region2)
return 3.75 * Math.sqrt(input - region1);
else if (input >= region2 && input < region3)
return 0.9;
else if (input >= region3 && input < region4)
return 0.9 + (input-region3);
else if (input >= region4 && input < region5)
return 0.9742 - 1.25 * (input-region4);
else if (input >= region5 && input < region6)
return 0.9742 - 1.25 * (region5-region4) - 0.75 * Math.sqrt(input - region5);
else
return 0.9742 - 1.25 * (region5-region4) - 0.75 * Math.sqrt(region6 - region5) + 28 * (input-region6) * (input-region6);
}
}