// $Id: OffsetIndexIterator.java,v 1.2 2002-05-29 20:32:40 steve Exp $
/*
* Copyright 1997-2000 Unidata Program Center/University Corporation for
* Atmospheric Research, P.O. Box 3000, Boulder, CO 80307,
* support@unidata.ucar.edu.
*
* 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; either version 2.1 of the License, or (at
* your option) any later version.
*
* 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.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package ucar.multiarray;
import java.lang.reflect.Array;
/**
* An IndexIterator where the lower bound is non-zero.
*
* @see IndexIterator
*
* @author $Author: steve $
* @version $Revision: 1.2 $ $Date: 2002-05-29 20:32:40 $
*/
public class
OffsetIndexIterator
extends IndexIterator
{
public
OffsetIndexIterator(int [] theOffset, int [] theLimits)
{
super(theOffset, theLimits);
offset = theOffset; // N.B. Not a copy
}
/**
* Increment the odometer
*/
public void
incr()
{
int digit = counter.length -1;
if(digit < 0)
{
// counter is zero length array <==> scalar
ncycles++;
return;
}
while(digit >= 0)
{
counter[digit]++;
if(counter[digit] < limits[digit])
{
break; // normal exit
}
// else, carry
counter[digit] = offset[digit];
if(digit == 0)
{
ncycles++; // rolled over
break;
}
// else
digit--;
}
}
private final int[] offset;
}