/**
* Copyright (C) 2009 - present by OpenGamma Inc. and the OpenGamma group of companies
*
* Please see distribution for license.
*/
package com.opengamma.analytics.math.surface;
import org.apache.commons.lang.Validate;
import com.opengamma.analytics.math.function.Function;
/**
* Shifts a {@link FunctionalDoublesSurface}. Only parallel shifts of the surface are supported.
*/
public class FunctionalSurfaceAdditiveShiftFunction implements SurfaceShiftFunction<FunctionalDoublesSurface> {
/**
* {@inheritDoc}
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double shift) {
Validate.notNull(surface, "surface");
return evaluate(surface, shift, "PARALLEL_SHIFT_" + surface.getName());
}
/**
* {@inheritDoc}
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double shift, final String newName) {
Validate.notNull(surface, "surface");
final Function<Double, Double> f = surface.getFunction();
final Function<Double, Double> shiftedFunction = new ShiftedFunction(shift, f);
return FunctionalDoublesSurface.from(shiftedFunction, newName);
}
private static class ShiftedFunction implements Function<Double, Double> {
private final double _shift;
private final Function<Double, Double> _f;
public ShiftedFunction(double shift, Function<Double, Double> f) {
this._shift = shift;
this._f = f;
}
@Override
public Double evaluate(final Double... xy) {
return _f.evaluate(xy) + _shift;
}
}
/**
* {@inheritDoc}
* @return Not supported
* @throws UnsupportedOperationException
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double x, final double y, final double shift) {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
* @return Not supported
* @throws UnsupportedOperationException
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double x, final double y, final double shift, final String newName) {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
* @return Not supported
* @throws UnsupportedOperationException
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double[] xShift, final double[] yShift, final double[] shift) {
throw new UnsupportedOperationException();
}
/**
* {@inheritDoc}
* @return Not supported
* @throws UnsupportedOperationException
*/
@Override
public FunctionalDoublesSurface evaluate(final FunctionalDoublesSurface surface, final double[] xShift, final double[] yShift, final double[] shift, final String newName) {
throw new UnsupportedOperationException();
}
}