/*******************************************************************************
* Copyright 2012 Geoscience Australia
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
******************************************************************************/
package au.gov.ga.earthsci.common.math.interpolation;
import au.gov.ga.earthsci.common.math.vector.Vector;
import au.gov.ga.earthsci.common.util.Validate;
/**
* A simple linear interpolator that interpolates linearly between a start and
* end vector
*
* @author James Navin (james.navin@ga.gov.au)
*/
public class LinearInterpolator<V extends Vector<V>> implements Interpolator<V>
{
private V start;
private V end;
/**
* Constructor. Initialises the start and end vectors.
*
* @param start
* @param end
*/
public LinearInterpolator(V start, V end)
{
Validate.notNull(start, "A start vector is required"); //$NON-NLS-1$
Validate.notNull(end, "An end vector is required"); //$NON-NLS-1$
this.start = start;
this.end = end;
}
@Override
public V computeValue(double percent)
{
return start.interpolate(end, percent);
}
/**
* @return the start
*/
public V getStart()
{
return start;
}
/**
* @param start
* the start to set
*/
public void setStart(V start)
{
Validate.notNull(start, "A start vector is required"); //$NON-NLS-1$
this.start = start;
}
/**
* @return the end
*/
public V getEnd()
{
return end;
}
/**
* @param end
* the end to set
*/
public void setEnd(V end)
{
Validate.notNull(end, "An end vector is required"); //$NON-NLS-1$
this.end = end;
}
}