All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ucar.ma2.IndexIterator Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 1998-2018 University Corporation for Atmospheric Research/Unidata
 * See LICENSE for license information.
 */
package ucar.ma2;

/**
 * Iteration through each element of an Array in "canonical order".
 * The user obtains this by calling getIndexIterator() on an Array.
 * 

* Canonical order for A[i][j][k] has k varying fastest, then j, then i.
*

* Example: Replace array with its square: *
* *

 * IndexIterator iter = A.getIndexIterator();
 * while (iter.hasNext()) {
 *   double val = iter.getDoubleNext();
 *   iter.setDoubleCurrent(val * val);
 * }
 * 
*

* Note that canonical order may not be physical order. * * @author caron */ public interface IndexIterator { /** * Return true if there are more elements in the iteration. * * @return true if there are more elements in the iteration. */ boolean hasNext(); /** * Get next value as a double * * @return next value as a double */ double getDoubleNext(); /** * Set next value with a double * * @param val the next value as a double */ void setDoubleNext(double val); /** * Get current value as a double * * @return current value as a double */ double getDoubleCurrent(); /** * Set current value with a double * * @param val the current value as a double */ void setDoubleCurrent(double val); /** * Get next value as a float * * @return next value as a float */ float getFloatNext(); /** * Set next value with a float * * @param val the next value as a float */ void setFloatNext(float val); /** * Get current value as a float * * @return current value as a float */ float getFloatCurrent(); /** * Set current value with a float * * @param val the current value as a float */ void setFloatCurrent(float val); /** * Get next value as a long * * @return next value as a long */ long getLongNext(); /** * Set next value with a long * * @param val the next value as a long */ void setLongNext(long val); /** * Get current value as a long * * @return current value as a long */ long getLongCurrent(); /** * Set current value with a long * * @param val the current value as a long */ void setLongCurrent(long val); /** * Get next value as a int * * @return next value as a int */ int getIntNext(); /** * Set next value with a int * * @param val the next value as a int */ void setIntNext(int val); /** * Get current value as a int * * @return current value as a int */ int getIntCurrent(); /** * Set current value with a int * * @param val the current value as a int */ void setIntCurrent(int val); /** * Get next value as a short * * @return next value as a short */ short getShortNext(); /** * Set next value with a short * * @param val the next value as a short */ void setShortNext(short val); /** * Get current value as a short * * @return current value as a short */ short getShortCurrent(); /** * Set current value with a short * * @param val the current value as a short */ void setShortCurrent(short val); /** * Get next value as a byte * * @return next value as a byte */ byte getByteNext(); /** * Set next value with a byte * * @param val the next value as a byte */ void setByteNext(byte val); /** * Get current value as a byte * * @return current value as a byte */ byte getByteCurrent(); /** * Set current value with a byte * * @param val the current value as a byte */ void setByteCurrent(byte val); /** * Get next value as a char * * @return next value as a char */ char getCharNext(); /** * Set next value with a char * * @param val the next value as a char */ void setCharNext(char val); /** * Get current value as a char * * @return current value as a char */ char getCharCurrent(); /** * Set current value with a char * * @param val the current value as a char */ void setCharCurrent(char val); /** * Get next value as a boolean * * @return next value as a boolean */ boolean getBooleanNext(); /** * Set next value with a boolean * * @param val the next value as a boolean */ void setBooleanNext(boolean val); /** * Get current value as a boolean * * @return current value as a boolean */ boolean getBooleanCurrent(); /** * Set current value with a boolean * * @param val the current value as a boolean */ void setBooleanCurrent(boolean val); /** * Get next value as an Object * * @return next value as an Object */ Object getObjectNext(); /** * Set next value with a Object * * @param val the next value as a Object */ void setObjectNext(Object val); /** * Get current value as a Object * * @return current value as a Object */ Object getObjectCurrent(); /** * Set current value with a Object * * @param val the current value as a Object */ void setObjectCurrent(Object val); /** * Get next value as an Object * * @return next value as an Object */ Object next(); /** * Get the current counter, use for debugging * * @return the current counter, use for debugging */ int[] getCurrentCounter(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy