org.geotoolkit.referencing.operation.transform.IdentityTransform1D Maven / Gradle / Ivy
/*
* Geotoolkit.org - An Open Source Java GIS Toolkit
* http://www.geotoolkit.org
*
* (C) 2002-2012, Open Source Geospatial Foundation (OSGeo)
* (C) 2009-2012, Geomatys
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*/
package org.geotoolkit.referencing.operation.transform;
import net.jcip.annotations.Immutable;
/**
* A one dimensional, identity transform. Output values are identical to input values.
* This class is really a special case of {@link LinearTransform1D} optimized for speed.
*
* @author Martin Desruisseaux (IRD)
* @version 3.00
*
* @since 2.0
* @module
*/
@Immutable
final class IdentityTransform1D extends LinearTransform1D {
/**
* Serial number for inter-operability with different versions.
*/
private static final long serialVersionUID = -7378774584053573789L;
/**
* Constructs a new identity transform.
*/
IdentityTransform1D() {
super(1, 0);
}
/**
* Transforms the specified value.
*/
@Override
public double transform(final double value) {
return value;
}
/**
* Transforms many coordinates in a list of ordinal values.
*/
@Override
public void transform(final double[] srcPts, int srcOff,
final double[] dstPts, int dstOff, int numPts)
{
System.arraycopy(srcPts, srcOff, dstPts, dstOff, numPts);
}
/**
* Transforms many coordinates in a list of ordinal values.
*/
@Override
public void transform(final float[] srcPts, int srcOff,
final float[] dstPts, int dstOff, int numPts)
{
System.arraycopy(srcPts, srcOff, dstPts, dstOff, numPts);
}
/**
* Transforms many coordinates in a list of ordinal values.
*/
@Override
public void transform(final double[] srcPts, int srcOff,
final float [] dstPts, int dstOff, int numPts)
{
while (--numPts >= 0) {
dstPts[dstOff++] = (float) srcPts[srcOff++];
}
}
/**
* Transforms many coordinates in a list of ordinal values.
*/
@Override
public void transform(final float [] srcPts, int srcOff,
final double[] dstPts, int dstOff, int numPts)
{
while (--numPts >= 0) {
dstPts[dstOff++] = srcPts[srcOff++];
}
}
}